/* ============================================================
   KANCELARIA ADWOKACKA OSKAR SKOCZYLAS — Design System Tokens
   ============================================================ */

/* Google Fonts loaded via wp_enqueue_style in functions.php — do not use @import */

:root {
  /* ── Tła (light mode) ── */
  --bg-primary: #F8F6F2;
  --bg-secondary: #F0EDE7;
  --bg-tertiary: #E4E0D9;
  --bg-elevated: #FFFFFF;

  /* ── Tekst ── */
  --text-primary: #0D0D0D;
  --text-secondary: #3D3D3D;
  --text-tertiary: #6B6B6B;
  --text-muted: #8A8A8A;
  --text-inverse: #F8F6F2;

  /* ── Akcent główny: Malachit ── */
  --accent: #2E6B47;
  --accent-hover: #3A7D56;
  --accent-light: #4A9A6A;
  --accent-bg: rgba(46,107,71,0.06);
  --accent-border: rgba(46,107,71,0.12);
  --accent-bg-solid: #EDF7F1;
  --accent-border-solid: #B8DDCA;

  /* ── Akcent premium: Szampan ── */
  --accent-champagne: #C5B99A;
  --champagne-bg-solid: #FAF8F3;
  --champagne-border-solid: #E4DCC8;

  /* ── Emergency / Pilne ── */
  --emergency-bg: #0D0D0D;
  --emergency-accent: #4A9A6A;
  --emergency-text: #F8F6F2;
  --emergency-glow: rgba(74,154,106,0.35);

  /* ── Dark mode ── */
  --dark-bg: #0F2D1F;
  --dark-bg-alt: #0D0D0D;
  --dark-bg-elevated: #1A3D2B;
  --dark-border: #2A4D3A;
  --dark-border-subtle: #1F3F2D;
  --dark-text: #F8F6F2;
  --dark-text-secondary: #C5C0B5;
  --dark-text-muted: #9AA89F;

  /* ── Obramowania (light mode) ── */
  --border: #E4E0D9;

  /* ── Cienie ── */
  --shadow-sm: 0 1px 3px rgba(13,13,13,0.04), 0 1px 2px rgba(13,13,13,0.03);
  --shadow-md: 0 4px 16px rgba(13,13,13,0.06), 0 2px 6px rgba(13,13,13,0.04);
  --shadow-lg: 0 12px 40px rgba(13,13,13,0.08), 0 4px 12px rgba(13,13,13,0.04);
  --shadow-focus: 0 0 0 3px rgba(46,107,71,0.15);

  /* ── Typografia ── */
  --font-body: 'Space Grotesk', system-ui, sans-serif;
  --font-display: 'Cormorant Garamond', Georgia, serif;

  /* ── Spacing (siatka 8px) ── */
  --space-1: 8px;
  --space-2: 16px;
  --space-3: 24px;
  --space-4: 32px;
  --space-5: 40px;
  --space-6: 48px;
  --space-7: 56px;
  --space-8: 64px;
  --space-9: 72px;
  --space-10: 80px;
}

/* ── Dark Mode ── */
[data-theme="dark"] {
  /* Tła */
  --bg-primary: #121212;
  --bg-secondary: #1A1A1A;
  --bg-tertiary: #2A2A2A;
  --bg-elevated: #1E1E1E;

  /* Tekst */
  --text-primary: #E8E4DE;
  --text-secondary: #C5C0B5;
  --text-tertiary: #9A9590;
  --text-muted: #6B6B6B;
  /* --text-inverse: NIE zmieniamy — zawsze jasny, bo używany na sekcjach z ciemnym bg (hero, emergency) */

  /* Akcent – jaśniejszy na ciemnym tle */
  --accent: #4A9A6A;
  --accent-hover: #5AAF7A;
  --accent-light: #6BC48A;
  --accent-bg: rgba(74,154,106,0.10);
  --accent-border: rgba(74,154,106,0.20);
  --accent-bg-solid: #1A2E22;
  --accent-border-solid: #2A4D3A;

  /* Szampan */
  --accent-champagne: #D4C9AB;
  --champagne-bg-solid: #1E1B16;
  --champagne-border-solid: #3D3526;

  /* Emergency – nieco ciemniejsze od strony */
  --emergency-bg: #0A0A0A;
  --emergency-glow: rgba(74,154,106,0.25);

  /* Dark sections — tła się lekko zmieniają, tekst NIE (--dark-text* zostaje jasny) */
  --dark-bg: #0F1F18;
  --dark-bg-alt: #0A0A0A;
  --dark-bg-elevated: #162E22;
  --dark-border: #253D32;
  --dark-border-subtle: #1C3328;
  /* --dark-text, --dark-text-secondary, --dark-text-muted: NIE nadpisujemy */

  /* Obramowania */
  --border: #2A2A2A;

  /* Cienie – mocniejsze na ciemnym tle */
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.20), 0 1px 2px rgba(0,0,0,0.15);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.25), 0 2px 6px rgba(0,0,0,0.20);
  --shadow-lg: 0 12px 40px rgba(0,0,0,0.35), 0 4px 12px rgba(0,0,0,0.25);
  --shadow-focus: 0 0 0 3px rgba(74,154,106,0.30);

  color-scheme: dark;
}

/* Dark mode: logo inversion for header */
[data-theme="dark"] .nav-logo__img {
  filter: brightness(0) invert(1);
}

/* Dark mode: media logos need to stay readable */
[data-theme="dark"] .media__logo-link:hover .media__logo--fakt { color: #FF5252; }
[data-theme="dark"] .media__logo-link:hover .media__logo--natemat { color: #9A9ACA; }
[data-theme="dark"] .media__logo-link:hover .media__logo--onet { color: #FFD54F; }
[data-theme="dark"] .media__logo-link:hover .media__logo--prawo { color: #66BB6A; }
[data-theme="dark"] .media__logo-link:hover .media__logo--trojka { color: #64B5F6; }

/* Dark mode: social share buttons */
[data-theme="dark"] .blog-share__btn--facebook:hover { color: #5A9CF6; border-color: #5A9CF6; }
[data-theme="dark"] .blog-share__btn--linkedin:hover { color: #4A9AE6; border-color: #4A9AE6; }
[data-theme="dark"] .blog-share__btn--whatsapp:hover { color: #4ADE80; border-color: #4ADE80; }

/* Dark mode: category badge colors on bw (baza-wiedzy) cards – keep vibrant */
[data-theme="dark"] .bw-card__badge { opacity: 0.9; }

/* Dark mode: images – subtle brightness reduction */
[data-theme="dark"] .bw-card__image,
[data-theme="dark"] .blog-hero__image img {
  filter: brightness(0.85);
}

/* Dark mode: hardcoded white text on buttons – keep white */
[data-theme="dark"] .btn-primary { color: #fff; }
[data-theme="dark"] .btn-accent { color: #0D0D0D; }

/* Dark mode: mega-menu */
[data-theme="dark"] .nav-mega {
  background: var(--bg-elevated);
  border-top-color: var(--border);
}

/* Dark mode: form inputs */
[data-theme="dark"] input,
[data-theme="dark"] textarea,
[data-theme="dark"] select {
  background: var(--bg-secondary);
  color: var(--text-primary);
  border-color: var(--border);
}

/* Dark mode: scrollbar */
[data-theme="dark"] ::-webkit-scrollbar-track { background: var(--bg-primary); }
[data-theme="dark"] ::-webkit-scrollbar-thumb { background: var(--bg-tertiary); }

/* Dark mode: mobile nav */
[data-theme="dark"] .mobile-nav {
  background: var(--bg-elevated);
}
[data-theme="dark"] .mobile-accordion__trigger {
  color: var(--text-primary);
}

/* Dark mode: case-card emergency variant — keep contrast */
[data-theme="dark"] .case-card--emergency {
  background: #0A0A0A;
  border-color: #1a1a1a;
}
[data-theme="dark"] .case-card--emergency:hover {
  background: #0F0F0F;
}

/* Dark mode: bw-search input */
[data-theme="dark"] .bw-search__input {
  background: var(--bg-secondary);
  color: var(--text-primary);
  border-color: var(--border);
}
[data-theme="dark"] .bw-search__dropdown {
  background: var(--bg-elevated);
  border-color: var(--border);
}

/* Dark mode: bw-card */
[data-theme="dark"] .bw-card {
  background: var(--bg-elevated);
  border-color: var(--border);
}

/* Dark mode: bw-sidebar CTA */
[data-theme="dark"] .bw-sidebar__cta {
  background: var(--bg-secondary);
  border-color: var(--border);
}

/* Dark mode: smooth transition on toggle click */
html.theme-transitioning,
html.theme-transitioning body {
  transition: background-color 0.3s ease, color 0.3s ease;
}

/* Dark mode: footer badge keep white bg for image visibility */
[data-theme="dark"] .footer__badge-img {
  background: #fff;
}

/* Dark mode: blog single – prose content */
[data-theme="dark"] .blog-content h2,
[data-theme="dark"] .blog-content h3,
[data-theme="dark"] .blog-content h4 {
  color: var(--text-primary);
}
[data-theme="dark"] .blog-content blockquote {
  border-left-color: var(--accent);
  background: var(--accent-bg);
}
[data-theme="dark"] .blog-content code {
  background: var(--bg-secondary);
  color: var(--accent-light);
}
[data-theme="dark"] .blog-content table th {
  background: var(--bg-secondary);
  color: var(--text-primary);
}
[data-theme="dark"] .blog-content table td {
  border-color: var(--border);
}

/* Dark mode: sort dropdown */
[data-theme="dark"] .bw-sort-dropdown__menu {
  background: var(--bg-elevated);
  border-color: var(--border);
}

/* Dark mode: bw filters */
[data-theme="dark"] .bw-filters__pill {
  background: var(--bg-secondary);
  color: var(--text-secondary);
  border-color: var(--border);
}
[data-theme="dark"] .bw-filters__pill.is-active {
  background: var(--accent);
  color: #fff;
}

/* Dark mode: pagination */
[data-theme="dark"] .bw-pagination__btn,
[data-theme="dark"] .bw-pagination__page {
  background: var(--bg-secondary);
  color: var(--text-secondary);
  border-color: var(--border);
}

/* Dark mode: pill buttons — fix rgba(0,0,0) borders invisible on dark bg */
[data-theme="dark"] .bw-filters__pill {
  border-color: var(--border);
}
[data-theme="dark"] .bw-filters__pill:hover {
  border-color: var(--text-muted);
  background: var(--bg-tertiary);
}
[data-theme="dark"] .bw-filters__pill-count {
  background: var(--bg-tertiary);
}

/* Dark mode: sort dropdown — fix borders and shadows */
[data-theme="dark"] .bw-sort-dropdown__trigger {
  border-color: var(--border);
}
[data-theme="dark"] .bw-sort-dropdown__trigger:hover {
  border-color: var(--text-muted);
}
[data-theme="dark"] .bw-sort-dropdown__menu {
  border-color: var(--border);
  box-shadow: 0 8px 32px rgba(0,0,0,0.4);
}

/* Dark mode: category badges — hardcoded colors */
[data-theme="dark"] [class*="bw-card__badge--"][class*="gospodarcze"] {
  color: #D4C9AB;
  background: var(--champagne-bg-solid);
}
[data-theme="dark"] [class*="bw-card__badge--"][class*="skarbowe"] {
  color: #7EB3D4;
  background: rgba(78,139,186,0.12);
}

/* Dark mode: search dropdown */
[data-theme="dark"] .bw-search__dropdown {
  box-shadow: 0 8px 32px rgba(0,0,0,0.4);
}
[data-theme="dark"] .bw-search__dropdown-item:hover {
  background: var(--bg-tertiary);
}

/* Dark mode: BW sidebar sections */
[data-theme="dark"] .bw-sidebar__section {
  background: var(--bg-elevated);
  border-color: var(--border);
}

/* Dark mode: contact form card */
[data-theme="dark"] .kt-form-card,
[data-theme="dark"] .kt-contact__calendar-card {
  background: var(--bg-elevated);
  border-color: var(--border);
}

/* Dark mode: cennik pricing cards */
[data-theme="dark"] .pricing-card {
  background: var(--bg-elevated);
  border-color: var(--border);
}

/* Dark mode: o-kancelarii sections — cards already use var() tokens */

/* Dark mode: specjalizacje orbit */
[data-theme="dark"] .orbit__tooltip {
  background: var(--bg-elevated);
  border-color: var(--border);
}

/* Dark mode: stabs (vertical tabs) */
[data-theme="dark"] .stabs__panel {
  background: var(--bg-elevated);
  border-color: var(--border);
}
[data-theme="dark"] .stab {
  color: var(--text-secondary);
}
[data-theme="dark"] .stab:hover {
  background: var(--bg-tertiary);
}
[data-theme="dark"] .stab.is-active {
  background: var(--accent-bg);
  color: var(--text-primary);
}

/* Dark mode: expert sidebar */
[data-theme="dark"] .expert__sidebar {
  color: var(--text-secondary);
}

/* Dark mode: blog single content area */
[data-theme="dark"] .blog-grid__main {
  color: var(--text-secondary);
}
[data-theme="dark"] .blog-sidebar__toc {
  background: var(--bg-elevated);
  border-color: var(--border);
}

/* Dark mode: mobile select */
[data-theme="dark"] .bw-filters__select {
  background: var(--bg-secondary);
  color: var(--text-primary);
  border-color: var(--border);
}

/* ── Bookmark button ── */
.bookmark-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  color: var(--text-muted);
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 100px;
  cursor: pointer;
  transition: all 0.25s ease;
  white-space: nowrap;
}
.bookmark-btn:hover {
  color: var(--accent);
  border-color: var(--accent-border-solid);
  background: var(--accent-bg);
}
.bookmark-btn.is-saved {
  color: var(--accent);
  border-color: var(--accent-border-solid);
  background: var(--accent-bg-solid);
}
.bookmark-btn svg {
  width: 14px;
  height: 14px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: fill 0.25s ease;
}
.bookmark-btn.is-saved svg {
  fill: currentColor;
}
.bookmark-btn__label--saved { display: none; }
.bookmark-btn.is-saved .bookmark-btn__label--default { display: none; }
.bookmark-btn.is-saved .bookmark-btn__label--saved { display: inline; }

/* Card bookmark — small icon in top-right corner of card image */
.bw-card__bookmark {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(4px);
  border: none;
  border-radius: 8px;
  cursor: pointer;
  z-index: 2;
  transition: all 0.2s ease;
  color: var(--text-muted);
  opacity: 0;
}
.bw-card:hover .bw-card__bookmark,
.bw-card__bookmark.is-saved {
  opacity: 1;
}
.bw-card__bookmark:hover {
  background: rgba(255,255,255,1);
  color: var(--accent);
}
.bw-card__bookmark.is-saved {
  background: var(--accent);
  color: #fff;
}
.bw-card__bookmark svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: fill 0.2s ease;
}
.bw-card__bookmark.is-saved svg {
  fill: currentColor;
}
[data-theme="dark"] .bw-card__bookmark {
  background: rgba(30,30,30,0.85);
  color: var(--text-muted);
}
[data-theme="dark"] .bw-card__bookmark:hover {
  background: rgba(30,30,30,1);
  color: var(--accent);
}
[data-theme="dark"] .bw-card__bookmark.is-saved {
  background: var(--accent);
  color: #fff;
}

/* Card image wrapper needs position relative for bookmark */
.bw-card__image-wrap {
  position: relative;
  overflow: hidden;
}

/* ── Sidebar: saved articles section ── */
.bw-sidebar__saved {
  display: none; /* shown by JS when there are bookmarks */
}
.bw-sidebar__saved.has-items {
  display: block;
}
.bw-sidebar__saved-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.bw-sidebar__saved-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
}
.bw-sidebar__saved-item:last-child {
  border-bottom: none;
}
.bw-sidebar__saved-link {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-primary);
  text-decoration: none;
  line-height: 1.4;
  flex: 1;
  min-width: 0;
  transition: color 0.2s ease;
}
.bw-sidebar__saved-link:hover {
  color: var(--accent);
}
.bw-sidebar__saved-remove {
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text-muted);
  flex-shrink: 0;
  border-radius: 4px;
  transition: all 0.2s ease;
}
.bw-sidebar__saved-remove:hover {
  color: var(--accent);
  background: var(--accent-bg);
}
.bw-sidebar__saved-remove svg {
  width: 14px;
  height: 14px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
}

/* ── Ask Form (contextual) ── */
.ask-form {
  background: var(--bg-secondary);
  padding: clamp(64px, 7vw, 112px) 0;
  position: relative;
}
.ask-form::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: min(90%, 1200px);
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--bg-tertiary), transparent);
}
.ask-form__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 5vw, 80px);
  align-items: start;
}
.ask-form__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 16px;
}
.ask-form__eyebrow::before {
  content: '';
  width: 24px;
  height: 1px;
  background: linear-gradient(90deg, var(--accent), transparent);
}
.ask-form__headline {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 1.2rem + 2.5vw, 2.75rem);
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.15;
  margin-bottom: 16px;
}
.ask-form__lead {
  font-family: var(--font-body);
  font-size: 15px;
  color: var(--text-secondary);
  line-height: 1.65;
  margin-bottom: 28px;
  max-width: 440px;
}
.ask-form__trust {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.ask-form__trust-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-tertiary);
}
.ask-form__trust-item svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  stroke: var(--accent);
}

/* Card */
.ask-form__card {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: clamp(24px, 3vw, 36px);
  box-shadow: var(--shadow-md);
}
.ask-form__form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.ask-form__category-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  color: var(--accent);
  background: var(--accent-bg-solid);
  border: 1px solid var(--accent-border-solid);
  border-radius: 100px;
  width: fit-content;
  margin-bottom: 4px;
}
.ask-form__category-badge svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}
.ask-form__group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.ask-form__label {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
}
.ask-form__req {
  color: var(--accent);
  font-weight: 700;
}
.ask-form__input,
.ask-form__textarea {
  width: 100%;
  padding: 12px 16px;
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text-primary);
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: 10px;
  outline: none;
  transition: border-color 0.25s ease, box-shadow 0.25s ease;
}
.ask-form__input::placeholder,
.ask-form__textarea::placeholder {
  color: var(--text-muted);
}
.ask-form__input:focus,
.ask-form__textarea:focus {
  border-color: var(--accent);
  box-shadow: var(--shadow-focus);
}
.ask-form__textarea {
  resize: vertical;
  min-height: 80px;
}
.ask-form__submit {
  width: 100%;
  justify-content: center;
  margin-top: 4px;
}
.ask-form__submit.is-loading {
  opacity: 0.7;
  pointer-events: none;
}
.ask-form__disclaimer {
  font-family: var(--font-body);
  font-size: 11px;
  color: var(--text-muted);
  line-height: 1.5;
  text-align: center;
}
.ask-form__disclaimer a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* Success state */
.ask-form__success {
  text-align: center;
  padding: 32px 16px;
}
.ask-form__success svg {
  width: 48px;
  height: 48px;
  stroke: var(--accent);
  margin-bottom: 16px;
}
.ask-form__success-title {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 8px;
}
.ask-form__success-text {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text-secondary);
  line-height: 1.6;
}
.ask-form__success-text a {
  color: var(--accent);
  font-weight: 600;
}

/* Responsive */
@media (max-width: 768px) {
  .ask-form__grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
}

/* ── Reading progress bar ── */
.reading-progress {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 3px;
  z-index: 1001;
  pointer-events: none;
  background: transparent;
}
.reading-progress__bar {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--accent), var(--accent-light));
  transition: width 0.1s linear;
  border-radius: 0 2px 2px 0;
}

/* ── Theme toggle button ── */
.theme-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 8px;
  background: transparent;
  border: 1px solid var(--bg-tertiary);
  cursor: pointer;
  transition: all 0.3s ease;
  color: var(--text-secondary);
  flex-shrink: 0;
}
.theme-toggle:hover {
  border-color: var(--accent);
  color: var(--accent);
}
.theme-toggle:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
}
.theme-toggle svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: transform 0.3s ease;
}
.theme-toggle:hover svg {
  transform: rotate(15deg);
}
/* Sun icon hidden by default (light mode shows moon) */
.theme-toggle__sun { display: none; }
.theme-toggle__moon { display: block; }
[data-theme="dark"] .theme-toggle__sun { display: block; }
[data-theme="dark"] .theme-toggle__moon { display: none; }

/* ── Reset ── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
@media (prefers-reduced-motion: no-preference) {
  html { scroll-behavior: smooth; }
}
body {
  background: var(--bg-primary);
  color: var(--text-secondary);
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}
a { text-decoration: none; color: inherit; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
ul, ol { list-style: none; }
h1, h2, h3, h4, h5, h6 { font-family: var(--font-display); }
em { font-style: normal; }

/* ── Container ── */
.container {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 clamp(20px, 12px + 3vw, 96px);
}

/* ── Keyframes ── */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(24px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes pulse {
  0%, 100% { opacity: 0; transform: scale(0.8); }
  50% { opacity: 0.4; transform: scale(1.6); }
}
@keyframes drawLine {
  from { transform: scaleY(0); }
  to { transform: scaleY(1); }
}

/* ── Pulse Dot (emergency) ── */
.pulse-dot {
  width: 8px;
  height: 8px;
  background: var(--emergency-accent);
  border-radius: 50%;
  position: relative;
  flex-shrink: 0;
}
.pulse-dot::after {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  background: var(--emergency-accent);
  opacity: 0;
  animation: pulse 2s ease-in-out infinite;
}

/* ── Buttons ── */
.btn-primary {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 16px 32px; background: var(--accent); color: #FFFFFF;
  font-family: var(--font-body); font-size: 14px; font-weight: 700;
  letter-spacing: 0.5px; border-radius: 6px; border: none;
  cursor: pointer; transition: all 0.3s ease;
}
.btn-primary:hover {
  background: var(--accent-hover);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(46,107,71,0.25);
}
.btn-primary svg { width: 18px; height: 18px; stroke: currentColor; fill: none; stroke-width: 2; }

.btn-accent {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 32px; background: var(--accent-light); color: var(--dark-bg);
  font-family: var(--font-body); font-size: 15px; font-weight: 700;
  border-radius: 10px; border: none; cursor: pointer; transition: all 0.3s ease;
}
.btn-accent:hover {
  background: #5AAF7A;
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(74,154,106,0.3);
}

.btn-ghost {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 16px 24px; background: transparent; color: var(--text-secondary);
  font-family: var(--font-body); font-size: 14px; font-weight: 600;
  border-radius: 6px; border: 1px solid var(--bg-tertiary);
  cursor: pointer; transition: all 0.3s ease;
}
.btn-ghost:hover {
  border-color: var(--accent); color: var(--text-primary);
  transform: translateY(-2px);
}

.btn-ghost-dark {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 32px; background: transparent; color: var(--dark-text);
  font-family: var(--font-body); font-size: 15px; font-weight: 600;
  border-radius: 10px; border: 1px solid var(--dark-border);
  cursor: pointer; transition: all 0.3s ease;
}
.btn-ghost-dark:hover {
  border-color: var(--accent-light); color: var(--accent-light);
  transform: translateY(-2px);
}

/* ── Reduced Motion ── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

/* ============================================================
   HEADER — Site Header
   ============================================================ */

.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  transition: transform 0.35s ease, box-shadow 0.35s ease;
}
.site-header.is-hidden {
  transform: translateY(-100%);
}
.site-header.is-scrolled {
  box-shadow: var(--shadow-md);
}

/* ── Top Bar (Layer 1) ── */
.top-bar {
  background: var(--dark-bg-alt);
  max-height: 44px;
  overflow: hidden;
  transition: max-height 0.35s ease, opacity 0.35s ease;
  opacity: 1;
}
.top-bar .container {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-3);
  height: 44px;
}
.top-bar__links {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-right: auto;
}
.top-bar__link {
  font-size: 12px;
  font-weight: 500;
  color: var(--dark-text-muted);
  transition: color 0.25s ease;
}
.top-bar__link:hover {
  color: var(--dark-text);
}
.top-bar__separator {
  width: 1px;
  height: 14px;
  background: var(--dark-border);
  flex-shrink: 0;
}
.top-bar__contact {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.top-bar__contact-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 500;
  color: var(--dark-text-secondary);
  transition: color 0.25s ease;
}
.top-bar__contact-item:hover {
  color: var(--accent-light);
}
.top-bar__contact-item svg {
  width: 14px;
  height: 14px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
}

.site-header.is-scrolled .top-bar {
  max-height: 0;
  opacity: 0;
}

/* ── Main Nav (Layer 2) ── */
.main-nav {
  background: var(--bg-elevated);
  border-bottom: 1px solid var(--bg-tertiary);
  transition: border-color 0.35s ease;
}
.main-nav .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding-top: 16px;
  padding-bottom: 16px;
  transition: padding 0.35s ease;
}
.site-header.is-scrolled .main-nav .container {
  padding-top: 10px;
  padding-bottom: 10px;
}
.site-header.is-scrolled .main-nav {
  border-color: transparent;
}

/* ── Logo ── */
.nav-logo {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  flex-shrink: 0;
}
.nav-logo__img {
  height: 40px;
  width: auto;
  display: block;
  transition: opacity 0.3s ease;
}
.nav-logo:hover .nav-logo__img {
  opacity: 0.8;
}

/* ── Nav Links ── */
.nav-links {
  display: flex;
  align-items: center;
  gap: clamp(16px, 2vw, 32px);
}
.nav-links__link,
.nav-links__trigger {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--text-secondary);
  padding: 8px 0;
  position: relative;
  transition: all 0.3s ease;
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.nav-links__link::after,
.nav-links__trigger::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--accent);
  transition: width 0.3s ease;
}
.nav-links__link:hover,
.nav-links__link:focus-visible,
.nav-links__trigger:hover,
.nav-links__trigger:focus-visible,
.nav-links__trigger[aria-expanded="true"] {
  color: var(--text-primary);
}
.nav-links__link:hover::after,
.nav-links__link:focus-visible::after,
.nav-links__trigger:hover::after,
.nav-links__trigger:focus-visible::after,
.nav-links__trigger[aria-expanded="true"]::after {
  width: 100%;
}
.nav-links__link:focus-visible,
.nav-links__trigger:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
  border-radius: 4px;
}
.nav-links__trigger-chevron {
  width: 14px;
  height: 14px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  transition: transform 0.3s ease;
}
.nav-links__trigger[aria-expanded="true"] .nav-links__trigger-chevron {
  transform: rotate(180deg);
}

/* ── Nav Actions (CTA + Phone) ── */
.nav-actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-shrink: 0;
}

.nav-emergency-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 20px;
  background: var(--emergency-bg);
  color: var(--emergency-text);
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 700;
  border-radius: 8px;
  transition: all 0.3s ease;
  white-space: nowrap;
}
.nav-emergency-cta:hover {
  background: #1a1a1a;
  box-shadow: 0 4px 16px rgba(74,154,106,0.2);
  transform: translateY(-1px);
}
.nav-emergency-cta:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
}

.nav-phone {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--text-secondary);
  padding: 8px 12px;
  border-radius: 6px;
  transition: all 0.3s ease;
}
.nav-phone:hover {
  color: var(--accent);
}
.nav-phone:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
}
.nav-phone__icon {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
}
.nav-phone__text {
  letter-spacing: 0.5px;
}

/* ── Hamburger ── */
.nav-hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  padding: 8px;
  border-radius: 6px;
  transition: all 0.3s ease;
}
.nav-hamburger:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
}
.nav-hamburger span {
  display: block;
  width: 100%;
  height: 2px;
  background: var(--text-primary);
  border-radius: 2px;
  transition: all 0.3s ease;
  transform-origin: center;
}
.nav-hamburger.is-open span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.nav-hamburger.is-open span:nth-child(2) {
  opacity: 0;
}
.nav-hamburger.is-open span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* ============================================================
   MEGA-MENU
   ============================================================ */

.nav-mega {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--bg-elevated);
  border-top: 1px solid var(--border);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  pointer-events: none;
  transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s ease;
  box-shadow: 0 16px 48px rgba(0,0,0,0.1), 0 4px 16px rgba(0,0,0,0.06);
}
.nav-mega.is-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

.nav-mega__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr) 1.2fr;
  gap: var(--space-4);
  padding-top: clamp(32px, 3vw, 48px);
  padding-bottom: clamp(32px, 3vw, 48px);
}

.nav-mega__col {
  min-width: 0;
}

.nav-mega__category {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--accent);
  padding-bottom: 12px;
  margin-bottom: 16px;
  border-bottom: 1px solid var(--border);
}
a.nav-mega__category-link {
  color: inherit;
  transition: color 0.25s ease;
}
a.nav-mega__category-link:hover {
  color: var(--text-primary);
}
a.nav-mega__category-link:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
  border-radius: 2px;
}

.nav-mega__list {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.nav-mega__link {
  display: block;
  padding: 6px 0;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 400;
  color: var(--text-secondary);
  transition: all 0.25s ease;
  border-radius: 4px;
}
.nav-mega__link:hover,
.nav-mega__link:focus-visible {
  color: var(--text-primary);
  padding-left: 4px;
}
.nav-mega__link:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
}

/* "More" link per column */
.nav-mega__more {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 8px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  transition: gap 0.25s ease;
}
.nav-mega__more:hover {
  gap: 8px;
}
.nav-mega__more svg {
  transition: transform 0.25s ease;
}
.nav-mega__more:hover svg {
  transform: translateX(2px);
}

/* Emergency column (Column 5) */
.nav-mega__emergency {
  background: var(--dark-bg);
  border-radius: 14px;
  padding: var(--space-3);
  border: 1px solid var(--dark-border);
  align-self: start;
}
.nav-mega__emergency .nav-mega__category {
  color: var(--emergency-accent);
  border-bottom-color: var(--dark-border);
}
.nav-mega__emergency .nav-mega__link {
  color: var(--dark-text-secondary);
  opacity: 0.85;
}
.nav-mega__emergency .nav-mega__link:hover,
.nav-mega__emergency .nav-mega__link:focus-visible {
  opacity: 1;
  color: #FFFFFF;
}

/* Emergency CTA — urgent button with glow animation */
@keyframes emergencyGlow {
  0%, 100% { box-shadow: 0 0 0 0 rgba(74,154,106,0.4), 0 4px 16px rgba(74,154,106,0.1); }
  50% { box-shadow: 0 0 20px 4px rgba(74,154,106,0.25), 0 4px 24px rgba(74,154,106,0.2); }
}
@keyframes emergencyShimmer {
  0% { left: -100%; }
  100% { left: 200%; }
}

.nav-mega__emergency-cta {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: var(--space-3);
  padding: 14px 24px;
  background: linear-gradient(135deg, var(--emergency-accent), #3A7D56);
  color: #FFFFFF;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.3px;
  border-radius: 10px;
  border: 1px solid rgba(74,154,106,0.3);
  transition: all 0.3s ease;
  justify-content: center;
  position: relative;
  overflow: hidden;
  animation: emergencyGlow 3s ease-in-out infinite;
}
.nav-mega__emergency-cta::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 60%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.12), transparent);
  animation: emergencyShimmer 4s ease-in-out infinite;
  pointer-events: none;
}
.nav-mega__emergency-cta:hover {
  background: linear-gradient(135deg, #5AAF7A, var(--emergency-accent));
  transform: translateY(-2px);
  box-shadow: 0 0 28px 6px rgba(74,154,106,0.3), 0 8px 32px rgba(74,154,106,0.25);
  animation: none;
}
.nav-mega__emergency-cta:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus), 0 0 20px 4px rgba(74,154,106,0.25);
}
.nav-mega__emergency-cta .pulse-dot {
  width: 10px;
  height: 10px;
}
.nav-mega__emergency-cta .pulse-dot::after {
  inset: -5px;
}
.nav-mega__emergency-cta svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
}

/* ============================================================
   MOBILE NAVIGATION
   ============================================================ */

.mobile-nav {
  position: fixed;
  inset: 0;
  z-index: 1001;
  background: var(--bg-elevated);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  opacity: 0;
  visibility: hidden;
  transform: translateX(100%);
  transition: opacity 0.35s ease, transform 0.35s ease, visibility 0.35s ease;
}
.mobile-nav.is-open {
  opacity: 1;
  visibility: visible;
  transform: translateX(0);
}
.mobile-nav__inner {
  padding: clamp(80px, 10vw, 100px) clamp(20px, 5vw, 40px) 40px;
  min-height: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.mobile-nav__close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-primary);
  border-radius: 8px;
  transition: all 0.3s ease;
}
.mobile-nav__close:hover {
  background: var(--bg-secondary);
}
.mobile-nav__close:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
}
.mobile-nav__close svg {
  width: 24px;
  height: 24px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
}

.mobile-nav__emergency-top {
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--border);
}
.mobile-nav__emergency-top .nav-emergency-cta {
  width: 100%;
  justify-content: center;
  padding: 14px 20px;
  font-size: 14px;
}

.mobile-nav__links {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.mobile-nav__link {
  display: block;
  padding: 14px 0;
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 600;
  color: var(--text-primary);
  border-bottom: 1px solid var(--border);
  transition: all 0.3s ease;
}
.mobile-nav__link:hover {
  color: var(--accent);
  padding-left: 4px;
}
.mobile-nav__link:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
  border-radius: 4px;
}

/* Mobile accordion */
.mobile-accordion {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.mobile-accordion__trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 14px 0;
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 0;
  text-transform: none;
  color: var(--text-primary);
  border-bottom: 1px solid var(--border);
  transition: all 0.3s ease;
  text-align: left;
}
.mobile-accordion__trigger:hover {
  color: var(--accent);
  padding-left: 4px;
}
.mobile-accordion__trigger:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
  border-radius: 4px;
}
.mobile-accordion__trigger-icon {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  transition: transform 0.3s ease;
  flex-shrink: 0;
}
.mobile-accordion__trigger[aria-expanded="true"] .mobile-accordion__trigger-icon {
  transform: rotate(180deg);
}
.mobile-accordion__panel {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.35s ease;
}
.mobile-accordion__list {
  display: flex;
  flex-direction: column;
  padding: var(--space-1) 0 var(--space-2) var(--space-2);
}
.mobile-accordion__link {
  display: block;
  padding: 8px 0;
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 400;
  color: var(--text-secondary);
  transition: all 0.25s ease;
}
.mobile-accordion__link:hover {
  color: var(--text-primary);
  padding-left: 4px;
}
.mobile-accordion__link:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
  border-radius: 4px;
}

/* Emergency accordion item */
.mobile-accordion__item--emergency {
  background: var(--dark-bg);
  border-radius: 12px;
  padding: 0 var(--space-2);
  margin-top: var(--space-1);
  border: 1px solid var(--dark-border);
}
.mobile-accordion__item--emergency .mobile-accordion__trigger {
  color: var(--emergency-accent);
  border-bottom-color: var(--dark-border);
  gap: 8px;
  justify-content: flex-start;
}
.mobile-accordion__item--emergency .mobile-accordion__trigger-icon {
  margin-left: auto;
}
.mobile-accordion__item--emergency .mobile-accordion__link {
  color: var(--dark-text-secondary);
  opacity: 0.85;
}
.mobile-accordion__item--emergency .mobile-accordion__link:hover {
  opacity: 1;
  color: #FFFFFF;
}

.mobile-nav__contact {
  margin-top: auto;
  padding-top: var(--space-3);
  border-top: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.mobile-nav__contact-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  color: var(--text-muted);
}
.mobile-nav__contact-item svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  flex-shrink: 0;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 1100px) {
  .nav-links {
    display: none;
  }
  .nav-hamburger {
    display: flex;
  }
  .nav-actions {
    display: none;
  }
  .top-bar {
    display: none;
  }
  .theme-toggle {
    order: 1;
    width: 32px;
    height: 32px;
  }
  .nav-hamburger {
    order: 2;
  }
}

@media (min-width: 601px) and (max-width: 1100px) {
  .nav-mega__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-3);
  }
  .nav-mega__emergency {
    grid-column: 1 / -1;
  }
}

@media (max-width: 600px) {
  .main-nav .container {
    padding-top: 8px;
    padding-bottom: 8px;
  }
  .nav-logo__sygnet {
    width: 36px;
    height: 36px;
    font-size: 17px;
    border-radius: 8px;
  }
  .nav-logo__text {
    display: none;
  }
  .nav-phone__text {
    display: none;
  }
  .nav-phone {
    padding: 8px;
  }
  .nav-mega__grid {
    grid-template-columns: 1fr;
    gap: var(--space-3);
  }
}

@media (min-width: 1101px) {
  .mobile-nav {
    display: none !important;
  }
  .nav-phone__icon {
    display: none;
  }
}

/* ── Body scroll lock ── */
body.no-scroll {
  overflow: hidden;
  position: fixed;
  width: 100%;
}

/* ============================================================
   HERO — Strona główna (prefix: hh-)
   ============================================================ */

/* Skip link (global — in header.php for all pages) */
.skip-link {
  position: absolute;
  top: -100%;
  left: 16px;
  background: var(--accent, #2E6B47);
  color: #fff;
  padding: 12px 24px;
  z-index: 10000;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 14px;
  font-weight: 600;
  border-radius: 0 0 8px 8px;
  text-decoration: none;
  transition: top 0.2s ease;
}
.skip-link:focus {
  top: 0;
}

/* ── Mobile accordion emergency link ── */
.mobile-accordion__link--emergency {
  color: var(--emergency-accent, #4A9A6A);
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 8px;
}

/* Sekcja hero — 90vh, above the fold */
.hh-hero {
  position: relative;
  background: var(--dark-bg);
  min-height: 90vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(96px, 12vw, 200px) 0 clamp(40px, 4vw, 56px);
  overflow: hidden;
}

/* Gradient overlays dla głębi */
.hh-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 20% 40%, rgba(46,107,71,0.05) 0%, transparent 70%),
    radial-gradient(ellipse 50% 80% at 85% 20%, rgba(46,107,71,0.03) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 50% 100%, rgba(0,0,0,0.3) 0%, transparent 70%);
  pointer-events: none;
}

/* Accent top line */
.hh-hero__topline {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--accent-light), var(--accent), var(--accent-light), transparent);
  opacity: 0.5;
}

/* Grid: 2 kolumny desktop — tekst dominuje */
.hh-hero__grid {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: clamp(32px, 3.5vw, 64px);
  align-items: stretch;
}

/* Kolumna tekstowa */
.hh-hero__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0;
}

/* Eyebrow badge */
.hh-hero__badge {
  margin-bottom: var(--space-2);
}
.hh-hero__badge span {
  display: inline-block;
  padding: 5px 14px;
  border-radius: 100px;
  background: rgba(46,107,71,0.08);
  border: 1px solid rgba(46,107,71,0.18);
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--accent-light);
}

/* H1 — zmniejszony, above the fold */
.hh-hero__heading {
  font-family: var(--font-display);
  font-size: clamp(2rem, 1.4rem + 3vw, 3.25rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--text-inverse);
  margin-bottom: var(--space-2);
}
.hh-hero__heading em {
  font-family: var(--font-display);
  font-style: normal;
  font-weight: 500;
  color: var(--accent-light);
}

/* Lead */
.hh-hero__lead {
  font-family: var(--font-body);
  font-size: clamp(1.05rem, 0.95rem + 0.5vw, 1.25rem);
  font-weight: 400;
  line-height: 1.6;
  color: var(--dark-text-secondary);
  max-width: 680px;
  margin-bottom: var(--space-3);
}

/* Testimonial slider */
.hh-hero__testimonials {
  margin-bottom: var(--space-4);
  max-width: 500px;
}
.hh-testimonial {
  position: relative;
  overflow: hidden;
  min-height: 52px;
  padding-left: var(--space-2);
  border-left: 2px solid var(--dark-border);
}
.hh-testimonial__track {
  position: relative;
}
.hh-testimonial__slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 0.4s ease, transform 0.4s ease;
  pointer-events: none;
}
.hh-testimonial__slide.is-active {
  position: relative;
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.hh-testimonial__slide p {
  font-family: var(--font-display);
  font-size: clamp(0.95rem, 0.85rem + 0.4vw, 1.1rem);
  font-style: normal;
  font-weight: 400;
  line-height: 1.5;
  color: var(--dark-text-secondary);
  margin-bottom: 4px;
}
.hh-testimonial__slide cite {
  font-family: var(--font-body);
  font-size: 11px;
  font-style: normal;
  font-weight: 600;
  color: var(--dark-text-muted);
  letter-spacing: 0.5px;
}
.hh-testimonial__dots {
  display: flex;
  flex-direction: row;
  gap: 8px;
  margin-top: 12px;
}
.hh-testimonial__dot {
  width: 6px;
  height: 6px;
  border-radius: 100px;
  background: var(--dark-border);
  border: none;
  padding: 0;
  cursor: pointer;
  transition: all 0.35s cubic-bezier(0.16, 1, 0.3, 1);
}
.hh-testimonial__dot.is-active {
  background: var(--accent-light);
  width: 24px;
}
.hh-testimonial__dot:hover {
  background: var(--accent-light);
}
.hh-testimonial__dot:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
}

/* Animacja wejścia testimonials — między lead a CTA */
.hh-anim--3b { animation-delay: 0.3s; }

/* CTA row */
.hh-hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-5);
}
.hh-hero__ctas .btn-accent svg,
.hh-hero__ctas .btn-ghost-dark svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
}
/* Focus visible na CTA */
.hh-hero__ctas .btn-accent:focus-visible,
.hh-hero__ctas .btn-ghost-dark:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
}

/* Trust indicators */
.hh-hero__trust {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}
.hh-hero__trust-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--dark-text-muted);
}
.hh-hero__trust-item svg {
  width: 14px;
  height: 14px;
  stroke: var(--accent-light);
  fill: none;
  flex-shrink: 0;
}

/* Media mentions — label nad nazwami */
.hh-hero__media {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.hh-hero__media-label {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  color: var(--dark-text-muted);
  text-transform: uppercase;
  letter-spacing: 1px;
}
.hh-hero__media-names {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
}
.hh-hero__media-name {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--dark-text-secondary);
  letter-spacing: 0.3px;
}
.hh-hero__media-sep {
  font-size: 11px;
  color: var(--dark-border);
  user-select: none;
}

/* Kolumna ze zdjęciem */
.hh-hero__photo {
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  min-height: 400px;
}
.hh-hero__photo img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}
/* Subtelny gradient na dole zdjęcia */
.hh-hero__photo::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 40%;
  background: linear-gradient(to top, rgba(15,45,31,0.4) 0%, transparent 100%);
  pointer-events: none;
}
/* Link-overlay na zdjęciu hero (inspirowany about-photo-overlay) */
.hh-hero__photo-link {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 2;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 6px;
  padding: 24px 20px 18px;
  background: linear-gradient(to top, rgba(13,13,13,0.7) 0%, rgba(13,13,13,0.3) 60%, transparent 100%);
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: rgba(255,255,255,0.85);
  text-decoration: none;
  letter-spacing: 0.02em;
  transition: color 0.25s ease;
}
.hh-hero__photo-link::after {
  content: '→';
  display: inline-block;
  transition: transform 0.25s ease;
}
.hh-hero__photo-link:hover {
  color: #fff;
}
.hh-hero__photo-link:hover::after {
  transform: translateX(3px);
}

/* ── Entrance animations ── */
@keyframes heroFadeInUp {
  from {
    opacity: 0;
    transform: translateY(28px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.hh-anim {
  opacity: 0;
  animation: heroFadeInUp 0.6s ease both;
}
.hh-anim--1 { animation-delay: 0.05s; }
.hh-anim--2 { animation-delay: 0.15s; }
.hh-anim--3 { animation-delay: 0.25s; }
.hh-anim--4 { animation-delay: 0.35s; }
.hh-anim--5 { animation-delay: 0.45s; }
.hh-anim--6 { animation-delay: 0.55s; }
.hh-anim--photo { animation-delay: 0.2s; }

/* ── Hero responsive ── */

/* Tablet (601–960px) */
@media (max-width: 960px) {
  .hh-hero__grid {
    grid-template-columns: 1fr;
    gap: var(--space-3);
  }
  .hh-hero__photo {
    order: 2;
    height: 360px;
    min-height: auto;
    border-radius: 14px;
  }
  .hh-hero__content {
    order: 1;
  }
}

/* Mobile (≤600px) */
@media (max-width: 600px) {
  .hh-hero {
    min-height: auto;
    padding: 80px 0 0;
  }
  .hh-hero__badge {
    margin-bottom: var(--space-2);
  }
  .hh-hero__heading {
    margin-bottom: var(--space-2);
  }
  .hh-hero__lead {
    margin-bottom: var(--space-3);
  }
  .hh-hero__testimonials {
    margin-bottom: var(--space-3);
  }
  .hh-testimonial__slide p {
    font-size: 0.9rem;
  }
  .hh-hero__ctas {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-1);
    margin-bottom: var(--space-4);
  }
  .hh-hero__ctas .btn-accent,
  .hh-hero__ctas .btn-ghost-dark {
    justify-content: center;
    text-align: center;
    padding: 12px 24px;
  }
  .hh-hero__trust {
    gap: var(--space-1) var(--space-2);
    margin-bottom: var(--space-3);
  }
  .hh-hero__trust-item {
    font-size: 12px;
  }
  .hh-hero {
    padding-bottom: 32px;
  }
  .hh-hero__photo {
    height: auto;
    aspect-ratio: 1 / 1;
    border-radius: 14px;
    margin-bottom: 0;
  }
  .hh-hero__media {
    gap: 4px;
    margin-bottom: var(--space-3);
  }
  .hh-hero__media-name {
    font-size: 12px;
  }
  .hh-hero__media-names {
    gap: 4px;
  }
}

/* ============================================================
   SECTION 2 — Value Strip (Social Proof)
   ============================================================ */

.vs {
  background: var(--bg-secondary);
  padding: clamp(16px, 2vw, 28px) 0;
}

.vs__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}

.vs__stat {
  text-align: center;
  padding: var(--space-3) var(--space-2);
  border-right: 1px solid var(--bg-tertiary);
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.vs__stat:last-child {
  border-right: none;
}

.vs--visible .vs__stat {
  opacity: 1;
  transform: translateY(0);
}

.vs--visible .vs__stat:nth-child(2) { transition-delay: 0.1s; }
.vs--visible .vs__stat:nth-child(3) { transition-delay: 0.2s; }
.vs--visible .vs__stat:nth-child(4) { transition-delay: 0.3s; }

.vs__number {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 2rem + 2vw, 4rem);
  font-weight: 600;
  line-height: 1.1;
  color: var(--accent);
  margin-bottom: var(--space-1);
}

.vs__label {
  display: block;
  font-family: var(--font-body);
  font-size: clamp(13px, 12px + 0.2vw, 15px);
  color: var(--text-muted);
  line-height: 1.5;
}

@media (max-width: 600px) {
  .vs {
    padding: 0;
    background: var(--bg-tertiary);
  }
  .vs > .container {
    padding-left: 0;
    padding-right: 0;
  }
  .vs__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1px;
  }
  .vs__stat {
    border-right: none;
    background: var(--bg-secondary);
    padding: var(--space-3) var(--space-2);
  }
}

/* ============================================================
   SECTION 3 — Specjalizacje (uses .stabs component)
   ============================================================ */


/* ============================================================
   SECTION 4 — O mnie (About)
   ============================================================ */

.about {
  background: var(--bg-secondary);
  padding: clamp(72px, 7vw, 128px) 0;
  position: relative;
}

.about__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(48px, 5vw, 96px);
  align-items: stretch;
}

/* ── Lewa kolumna: karta ze zdjęciem ── */
.about__photo {
  display: flex;
}

.about-photo-card {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: var(--shadow-md);
  flex: 1;
}

.about-photo-card__img-wrap {
  position: relative;
  height: 100%;
}

.about-photo-card__img-wrap img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  border-radius: 16px;
}

.about-photo-overlay {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 32px 24px 24px;
  background: linear-gradient(to top, rgba(13,13,13,0.8) 0%, rgba(13,13,13,0.4) 50%, transparent 100%);
  border-radius: 0 0 16px 16px;
}

.about-photo-overlay__name {
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 600;
  color: var(--text-inverse);
  line-height: 1.3;
}

.about-photo-overlay__title {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 400;
  color: var(--dark-text-secondary);
  margin-top: 2px;
}

/* ── Prawa kolumna: treść ── */
.about-eyebrow {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.about-eyebrow::before {
  content: '';
  width: 32px; height: 1px;
  background: linear-gradient(90deg, var(--accent), transparent);
}

.about-headline {
  font-family: var(--font-display);
  font-size: clamp(2.25rem, 1.6rem + 3.2vw, 3.5rem);
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin-bottom: 24px;
}
.about-headline em {
  font-style: normal;
  font-weight: 500;
  color: var(--accent);
}

.about-text {
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 400;
  color: var(--text-secondary);
  line-height: 1.7;
  margin-bottom: 24px;
}

.about-quote {
  font-family: var(--font-display);
  font-size: clamp(1.15rem, 1rem + 0.7vw, 1.5rem);
  font-weight: 500;
  font-style: normal;
  color: var(--text-primary);
  line-height: 1.5;
  padding-left: 24px;
  border-left: 3px solid var(--accent);
  margin: 32px 0;
}

/* ── Credentials grid ── */
.about-creds {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}

.about-cred {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 18px;
  background: var(--bg-elevated);
  border: 1px solid var(--bg-tertiary);
  border-radius: 12px;
}

.about-cred__icon {
  width: 40px; height: 40px;
  border-radius: 10px;
  background: var(--accent-bg-solid);
  border: 1px solid var(--accent-border-solid);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.about-cred__icon svg {
  width: 18px; height: 18px;
  stroke: var(--accent);
  fill: none;
  stroke-width: 1.5;
}

.about-cred__text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.about-cred__label {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 400;
  color: var(--text-muted);
}

.about-cred__value {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.3;
}

/* ── CTA ── */
.about-cta {
  margin-top: 32px;
}
.about-cta svg {
  transition: transform 0.3s ease;
}
.about-cta:hover svg {
  transform: translateX(3px);
}

/* ── Reveal animations ── */
.about-reveal {
  opacity: 0;
  transform: translateY(32px);
}
.about-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}

.about-cred-reveal {
  opacity: 0;
  transform: translateY(24px);
}
.about-cred-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.6s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

/* ── About responsive ── */
@media (max-width: 1023px) {
  .about__grid {
    gap: 32px;
  }
}

@media (max-width: 767px) {
  .about__grid {
    grid-template-columns: 1fr;
  }
  .about__photo {
    max-width: 400px;
    margin: 0 auto;
  }
  .about-creds {
    grid-template-columns: 1fr;
  }
}

/* ============================================================
   SECTION 5 – DLACZEGO WARTO (Bento Grid)
   ============================================================ */
.why {
  background: var(--bg-primary);
  padding: clamp(72px, 7vw, 128px) 0;
}

/* ── Header ── */
.why__header {
  text-align: center;
  margin-bottom: clamp(40px, 4vw, 64px);
}

.why__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 20px;
}

.why__eyebrow::before,
.why__eyebrow::after {
  content: '';
  width: 28px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--accent));
}

.why__eyebrow::after {
  background: linear-gradient(90deg, var(--accent), transparent);
}

.why__headline {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 1.2rem + 2.5vw, 2.75rem);
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.2;
  max-width: 640px;
  margin: 0 auto;
}

/* ── Bento Grid: top 3fr+2fr, bottom 3×1fr ── */
.why__grid {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: 16px;
}

/* Featured + specialization span top row */
.why__card--featured { grid-column: 1; }
.why__card:nth-child(2) { grid-column: 2; }

/* Bottom three cards in equal thirds */
.why__card:nth-child(3),
.why__card:nth-child(4),
.why__card:nth-child(5) {
  grid-column: auto;
}

.why__grid-bottom {
  display: contents;
}

/* ── Card base ── */
.why__card {
  background: var(--bg-elevated);
  border: 1px solid var(--bg-tertiary);
  border-radius: 16px;
  overflow: hidden;
  position: relative;
  transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1),
              box-shadow 0.35s cubic-bezier(0.16, 1, 0.3, 1);
}

.why__card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

/* 6. Accent top line on standard cards */
.why__card:not(.why__card--featured)::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--accent), var(--accent-light));
  opacity: 0;
  transition: opacity 0.35s ease;
  z-index: 2;
}

.why__card:not(.why__card--featured):hover::before {
  opacity: 1;
}

/* 2. Icon animation on hover */
.why__card:hover .why__icon {
  transform: scale(1.08) rotate(-3deg);
}

.why__card-inner {
  padding: clamp(24px, 2.5vw, 32px);
  height: 100%;
  display: flex;
  flex-direction: column;
  position: relative;
  z-index: 1;
}

/* 7. Watermark background icons */
.why__watermark {
  position: absolute;
  bottom: -30px;
  right: -30px;
  width: 240px;
  height: 240px;
  stroke: var(--accent);
  stroke-width: 0.3;
  fill: none;
  opacity: 0.04;
  pointer-events: none;
  z-index: 0;
  transition: opacity 0.4s ease;
}

.why__card:hover .why__watermark {
  opacity: 0.07;
}

/* ── Featured card: dark background ── */
.why__card--featured {
  background: var(--emergency-bg);
  border-color: rgba(255,255,255,0.06);
}

/* 4. Noise texture on featured card */
.why__card--featured::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 16px;
  opacity: 0.03;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 128px 128px;
  pointer-events: none;
  mix-blend-mode: overlay;
  z-index: 1;
}

/* Radial green accents */
.why__card--featured .why__card-inner::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 16px;
  background:
    radial-gradient(ellipse at 10% 90%, rgba(74,154,106,0.1) 0%, transparent 50%),
    radial-gradient(ellipse at 90% 10%, rgba(74,154,106,0.06) 0%, transparent 50%);
  pointer-events: none;
  z-index: -1;
}

/* 1. Glow on hover */
.why__card--featured:hover {
  box-shadow:
    0 12px 40px rgba(0,0,0,0.35),
    0 4px 12px rgba(0,0,0,0.2),
    0 0 60px rgba(74,154,106,0.15),
    0 0 120px rgba(74,154,106,0.08);
}

/* 5. Animated border gradient */
@property --why-border-angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}

.why__card--featured {
  padding: 1.5px;
  background:
    conic-gradient(
      from var(--why-border-angle, 0deg),
      rgba(74,154,106,0.5),
      rgba(74,154,106,0.05),
      rgba(74,154,106,0.05),
      rgba(74,154,106,0.5),
      rgba(74,154,106,0.05),
      rgba(74,154,106,0.05),
      rgba(74,154,106,0.5)
    );
  animation: whyBorderSpin 8s linear infinite;
}

@keyframes whyBorderSpin {
  to { --why-border-angle: 360deg; }
}

.why__card--featured .why__card-inner {
  background: var(--emergency-bg);
  border-radius: 15px;
  padding: clamp(32px, 3vw, 44px);
  position: relative;
  z-index: 2;
}

.why__card--featured .why__card-title {
  color: var(--emergency-text);
  font-size: clamp(1.5rem, 1.1rem + 1.5vw, 2rem);
}

.why__card--featured .why__card-text {
  color: var(--dark-text-secondary);
}

/* 2. Featured icon hover */
.why__card--featured:hover .why__icon {
  transform: scale(1.08) rotate(-3deg);
}

/* ── Featured icon ── */
.why__icon--featured {
  background: rgba(74,154,106,0.12);
  border-color: rgba(74,154,106,0.22);
  transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1);
}

.why__icon--featured svg {
  stroke: var(--emergency-accent);
}

/* ── Badge (featured card top pill) ── */
.why__badge {
  display: inline-flex;
  align-items: center;
  padding: 5px 14px;
  border-radius: 100px;
  background: rgba(74,154,106,0.1);
  border: 1px solid rgba(74,154,106,0.2);
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--emergency-accent);
  margin-bottom: 20px;
  width: fit-content;
}

/* ── Checkmark list (featured card, dark variant) ── */
.why__checks {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 20px;
  margin-bottom: 24px;
  list-style: none;
}

.why__checks li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  color: var(--dark-text-secondary);
  line-height: 1.4;
}

.why__checks svg {
  width: 18px;
  height: 18px;
  stroke: var(--emergency-accent);
  flex-shrink: 0;
}

/* ── Checkmark list (light variant for standard cards) ── */
.why__checks--light li {
  color: var(--text-secondary);
}

.why__checks--light svg {
  stroke: var(--accent);
}

/* ── Featured CTA (ghost button on dark card) ── */
.why__cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: auto;
  padding: 12px 24px;
  border-radius: 8px;
  border: 1px solid var(--dark-border);
  background: transparent;
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 600;
  color: var(--emergency-text);
  letter-spacing: 0.02em;
  text-decoration: none;
  transition: all 0.3s ease;
  width: fit-content;
}

.why__cta svg {
  width: 16px;
  height: 16px;
  stroke: var(--emergency-accent);
  fill: none;
  flex-shrink: 0;
}

.why__cta:hover {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--text-inverse);
}

.why__cta:hover svg {
  stroke: var(--text-inverse);
}

.why__cta:focus-visible {
  outline: 2px solid var(--emergency-accent);
  outline-offset: 3px;
}

/* ── Featured top: icon + hero stat side by side ── */
.why__featured-top {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 4px;
}

.why__featured-top .why__icon {
  margin-bottom: 0;
}

.why__hero-stat {
  font-family: var(--font-body);
  font-size: clamp(3rem, 2rem + 4vw, 4.5rem);
  font-weight: 700;
  color: var(--emergency-accent);
  line-height: 1;
  letter-spacing: -0.03em;
  opacity: 0.25;
}

/* ── Divider ── */
.why__divider {
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--dark-border) 20%, var(--dark-border) 80%, transparent 100%);
  margin: 16px 0;
}

.why__divider--light {
  background: linear-gradient(90deg, transparent 0%, var(--bg-tertiary) 20%, var(--bg-tertiary) 80%, transparent 100%);
}

/* ── Testimonial (featured card) ── */
.why__testimonial {
  margin-bottom: 20px;
}

.why__testimonial p {
  font-family: var(--font-display);
  font-size: clamp(0.95rem, 0.85rem + 0.5vw, 1.1rem);
  font-style: italic;
  color: var(--dark-text-secondary);
  line-height: 1.5;
  margin-bottom: 6px;
}

.why__testimonial cite {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  font-style: normal;
  color: var(--dark-text-muted);
  letter-spacing: 0.03em;
}

/* ── Mini stats grid (Tylko prawo karne) ── */
.why__mini-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin: 16px 0;
}

.why__mini-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 12px 4px;
  background: var(--accent-bg);
  border: 1px solid var(--accent-border);
  border-radius: 10px;
}

.why__mini-stat-num {
  font-family: var(--font-body);
  font-size: clamp(1.1rem, 0.9rem + 0.8vw, 1.4rem);
  font-weight: 700;
  color: var(--accent);
  line-height: 1;
  margin-bottom: 4px;
}

.why__mini-stat-label {
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* ── Spec tags (Tylko prawo karne) ── */
.why__spec-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 14px;
}

.why__spec-tag {
  padding: 4px 12px;
  border-radius: 100px;
  background: var(--bg-secondary);
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  color: var(--text-tertiary);
  text-decoration: none;
  transition: all 0.2s ease;
}

.why__spec-tag:hover {
  background: var(--accent-bg-solid);
  color: var(--accent);
}

/* ── Icon (standard cards) ── */
.why__icon {
  width: 44px;
  height: 44px;
  border-radius: 10px;
  background: var(--accent-bg-solid);
  border: 1px solid var(--accent-border-solid);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-bottom: 16px;
  transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1);
}

.why__icon svg {
  width: 20px;
  height: 20px;
  stroke: var(--accent);
  fill: none;
  stroke-width: 1.5;
}

/* ── Tag pill (standard cards) ── */
.why__tag {
  display: inline-block;
  padding: 4px 12px;
  border-radius: 100px;
  background: var(--accent-bg);
  border: 1px solid var(--accent-border);
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 12px;
  width: fit-content;
}

/* ── Card title ── */
.why__card-title {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 1rem + 0.8vw, 1.5rem);
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.2;
  margin-bottom: 10px;
}

/* ── Card text ── */
.why__card-text {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 400;
  color: var(--text-secondary);
  line-height: 1.7;
}

/* ── Stat component ── */
.why__stat {
  display: flex;
  align-items: baseline;
  gap: 6px;
  margin-bottom: 12px;
}

.why__stat-number {
  font-family: var(--font-body);
  font-size: clamp(1.75rem, 1.3rem + 1.8vw, 2.5rem);
  font-weight: 700;
  color: var(--accent);
  line-height: 1;
  letter-spacing: -0.02em;
}

.why__stat--sm .why__stat-number {
  font-size: clamp(1.5rem, 1.2rem + 1.2vw, 2rem);
}

.why__stat-label {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-tertiary);
}

/* ── Text link with arrow ── */
.why__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: auto;
  padding-top: 14px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  transition: gap 0.3s ease;
}

.why__link svg {
  width: 16px;
  height: 16px;
  transition: transform 0.3s ease;
}

.why__link:hover {
  gap: 10px;
}

.why__link:hover svg {
  transform: translateX(2px);
}

.why__link:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
  border-radius: 3px;
}

/* ── Mini list ── */
.why__mini-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 12px;
}

.why__mini-list li {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-secondary);
  padding-left: 18px;
  position: relative;
  line-height: 1.5;
}

.why__mini-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 7px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
}

/* ── Reveal animations ── */
.why-reveal {
  opacity: 0;
  transform: translateY(32px);
}

.why-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}

.why-card-reveal {
  opacity: 0;
  transform: translateY(28px);
}

.why-card-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.6s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

@media (prefers-reduced-motion: reduce) {
  .why-reveal,
  .why-card-reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }
  .why__card--featured {
    animation: none;
  }
  .why__card:hover .why__icon {
    transform: none;
  }
}

/* ── Responsive: bottom 3 cards as equal row ── */
@media (min-width: 768px) {
  .why__grid {
    grid-template-columns: 3fr 2fr;
    grid-template-rows: auto auto;
  }
  /* Row 2: re-layout bottom 3 cards into equal thirds */
  .why__card:nth-child(n+3) {
    grid-column: auto;
  }
  /* Force bottom row to span full width as 3 equal columns */
  .why__grid {
    grid-template-columns: repeat(6, 1fr);
  }
  .why__card--featured { grid-column: 1 / 4; grid-row: 1; }
  .why__card:nth-child(2) { grid-column: 4 / 7; grid-row: 1; }
  .why__card:nth-child(3) { grid-column: 1 / 3; grid-row: 2; }
  .why__card:nth-child(4) { grid-column: 3 / 5; grid-row: 2; }
  .why__card:nth-child(5) { grid-column: 5 / 7; grid-row: 2; }
}

/* ── Responsive: Tablet ── */
@media (max-width: 1023px) and (min-width: 768px) {
  .why__grid {
    grid-template-columns: repeat(6, 1fr);
  }
  .why__card--featured { grid-column: 1 / 7; grid-row: 1; }
  .why__card:nth-child(2) { grid-column: 1 / 4; grid-row: 2; }
  .why__card:nth-child(3) { grid-column: 4 / 7; grid-row: 2; }
  .why__card:nth-child(4) { grid-column: 1 / 4; grid-row: 3; }
  .why__card:nth-child(5) { grid-column: 4 / 7; grid-row: 3; }
}

/* ── Responsive: Mobile ── */
@media (max-width: 767px) {
  .why__grid {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  /* Top 2 cards: full width stacked */
  .why__card--featured,
  .why__card:nth-child(2) {
    grid-column: 1 / -1;
  }

  /* Bottom 3 cards: 2+1 layout */
  .why__card:nth-child(3),
  .why__card:nth-child(4) {
    grid-column: span 1;
  }
  .why__card:nth-child(5) {
    grid-column: 1 / -1;
  }

  /* Compact padding on smaller cards */
  .why__card:nth-child(n+3) .why__card-inner {
    padding: 18px;
  }

  .why__card--featured .why__card-inner {
    padding: clamp(24px, 5vw, 36px);
  }

  .why__card:nth-child(n+3) .why__card-title {
    font-size: 1rem;
  }

  .why__card:nth-child(n+3) .why__card-text {
    font-size: 0.82rem;
    line-height: 1.45;
  }

  .why__card:nth-child(n+3) .why__stat-number {
    font-size: 1.5rem;
  }

  .why__card:nth-child(n+3) .why__watermark {
    width: 140px;
    height: 140px;
    bottom: -20px;
    right: -20px;
  }

  .why__cta {
    width: 100%;
    justify-content: center;
  }
}


/* ============================================================
   SECTION 6 – PANEL KLIENTA (Feature Showcase)
   ============================================================ */
.cpanel {
  background: var(--bg-secondary, #F0EDE7);
  padding: clamp(64px, 8vw, 120px) 0;
  overflow: hidden;
}

.cpanel__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8, 64px);
  align-items: center;
}

/* ── Left column: content ── */
.cpanel__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-body, 'Space Grotesk', sans-serif);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent, #2E6B47);
  margin-bottom: var(--space-2, 16px);
}

/* Pulsujący dot sygnalizuje "live" status panelu */
.cpanel__eyebrow-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent, #2E6B47);
  animation: cpanelPulse 2s ease-in-out infinite;
}

@keyframes cpanelPulse {
  0%, 100% { opacity: 1; box-shadow: 0 0 0 0 rgba(46,107,71,0.4); }
  50% { opacity: 0.7; box-shadow: 0 0 0 6px rgba(46,107,71,0); }
}

.cpanel__headline {
  font-family: var(--font-display, 'Cormorant Garamond', serif);
  font-size: clamp(2rem, 1.4rem + 3vw, 3.25rem);
  font-weight: 700;
  line-height: 1.15;
  color: var(--text-primary, #0D0D0D);
  margin-bottom: var(--space-3, 24px);
}

.cpanel__headline em {
  font-style: normal;
  color: var(--accent, #2E6B47);
}

.cpanel__lead {
  font-family: var(--font-body, 'Space Grotesk', sans-serif);
  font-size: 15px;
  line-height: 1.65;
  color: var(--text-secondary, #3D3D3D);
  margin-bottom: var(--space-4, 32px);
}

/* ── Benefit list ── */
.cpanel__benefits {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-2, 16px);
  margin-bottom: var(--space-4, 32px);
}

.cpanel__benefit {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2, 16px);
  font-family: var(--font-body, 'Space Grotesk', sans-serif);
  font-size: 15px;
  line-height: 1.5;
  color: var(--text-secondary, #3D3D3D);
}

.cpanel__benefit-icon {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: var(--accent-bg, rgba(46,107,71,0.06));
  border: 1px solid var(--accent-border, rgba(46,107,71,0.12));
  display: flex;
  align-items: center;
  justify-content: center;
}

.cpanel__benefit-icon svg {
  width: 18px;
  height: 18px;
  stroke: var(--accent, #2E6B47);
  fill: none;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.cpanel__benefit-text {
  padding-top: 6px;
  font-family: var(--font-body, 'Space Grotesk', sans-serif);
  font-size: 14px;
  line-height: 1.6;
  color: var(--text-tertiary, #6B6B6B);
}

.cpanel__benefit-text strong {
  display: block;
  font-size: 15px;
  font-weight: 600;
  color: var(--text-primary, #0D0D0D);
  margin-bottom: 2px;
}

.cpanel__cta {
  text-decoration: none;
}

/* ── Right column: screenshot placeholder ── */
.cpanel__screenshot-frame {
  background: var(--bg-elevated, #FFFFFF);
  border-radius: 16px;
  box-shadow:
    var(--shadow-lg, 0 12px 40px rgba(13,13,13,0.08)),
    0 0 0 1px rgba(13,13,13,0.04);
  overflow: hidden;
}

.cpanel__screenshot-frame img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ── Reveal animations ── */
.cpanel-reveal {
  opacity: 0;
  transform: translateY(32px);
}

.cpanel-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}

@media (prefers-reduced-motion: reduce) {
  .cpanel-reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }
  .cpanel__eyebrow-dot {
    animation: none;
  }
  .cpanel__mock-progress-fill {
    transition: none;
  }
}

/* ── Responsive: Desktop — równe kolumny ── */
@media (min-width: 960px) {
  .cpanel__grid {
    grid-template-columns: 1fr 1fr;
    gap: clamp(48px, 5vw, 80px);
  }
}

/* ============================================================
   ECTA — Emergency CTA Section
   ============================================================ */
@property --card-angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}
@property --scan-angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}
.ecta {
  width: 100%;
  background: var(--emergency-bg);
  padding: clamp(48px, 6vw, 80px) 0;
  overflow: hidden;
}
.ecta__container {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 clamp(20px, 12px + 3vw, 96px);
}
.ecta__grid {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: clamp(40px, 5vw, 80px);
  align-items: center;
}
.ecta-reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}
.ecta-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.ecta__card.ecta-reveal { transition-delay: 0.15s; }
.ecta__tag {
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.4s ease, transform 0.4s ease,
              background 0.3s ease, border-color 0.3s ease, color 0.3s ease;
}
.ecta__tags.is-visible .ecta__tag {
  opacity: 1;
  transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
  .ecta-reveal { opacity: 1; transform: none; transition: none; }
  .ecta__tag { opacity: 1; transform: none; transition: background 0.3s ease, border-color 0.3s ease, color 0.3s ease; }
}
.ecta__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 24px;
}
.ecta__eyebrow-text {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--emergency-accent);
}
.ecta__dot {
  width: 10px; height: 10px;
  background: var(--emergency-accent);
  border-radius: 50%;
  position: relative;
  flex-shrink: 0;
}
.ecta__dot::after {
  content: '';
  position: absolute;
  inset: -5px;
  border-radius: 50%;
  background: var(--emergency-accent);
  opacity: 0;
  animation: ectaPulse 2s ease-in-out infinite;
}
@keyframes ectaPulse {
  0%   { transform: scale(0.8); opacity: 0.6; }
  50%  { transform: scale(2); opacity: 0; }
  100% { transform: scale(2); opacity: 0; }
}
.ecta__headline {
  font-family: var(--font-display);
  font-size: clamp(2rem, 1.4rem + 2.5vw, 3.25rem);
  font-weight: 600;
  line-height: 1.2;
  color: var(--emergency-text);
  margin-bottom: 24px;
  max-width: 560px;
}
.ecta__desc {
  font-size: 15px;
  line-height: 1.7;
  color: var(--dark-text-secondary);
  margin-bottom: 28px;
  max-width: 480px;
}
.ecta__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 28px;
}
.ecta__tag {
  padding: 6px 16px;
  border-radius: 100px;
  background: rgba(74,154,106,0.08);
  border: 1px solid rgba(74,154,106,0.18);
  font-size: 12px;
  font-weight: 600;
  color: var(--emergency-accent);
  text-decoration: none;
}
.ecta__tag:hover {
  background: var(--emergency-accent);
  color: var(--emergency-bg);
  border-color: var(--emergency-accent);
  transform: translateY(-1px);
}
.ecta__tag:focus-visible { outline: 2px solid var(--emergency-accent); outline-offset: 2px; }
.ecta__footer {
  font-size: 13px;
  font-weight: 600;
  color: var(--dark-text-muted);
  letter-spacing: 0.3px;
}
.ecta__card {
  position: relative;
  border-radius: 20px;
  padding: 1.5px;
  perspective: 1200px;
}
.ecta__card-tilt {
  border-radius: 20px;
  position: relative;
  transition: transform 0.1s ease-out;
  will-change: transform;
}
.ecta__card-tilt::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 20px;
  padding: 1.5px;
  background: conic-gradient(from var(--card-angle, 0deg), rgba(74,154,106,0.6), rgba(74,154,106,0.05), rgba(74,154,106,0.05), rgba(74,154,106,0.6), rgba(74,154,106,0.05), rgba(74,154,106,0.05), rgba(74,154,106,0.6));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  animation: ectaBorderSpin 8s linear infinite;
  z-index: 1;
}
@keyframes ectaBorderSpin { to { --card-angle: 360deg; } }
.ecta__card-tilt::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 20px;
  padding: 2px;
  background: conic-gradient(from var(--scan-angle, 0deg), transparent 340deg, rgba(74,154,106,0.8) 352deg, rgba(74,154,106,0.3) 356deg, transparent 360deg);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  animation: ectaScanSpin 3.5s linear infinite;
  filter: blur(3px);
  z-index: 2;
}
@keyframes ectaScanSpin { to { --scan-angle: 360deg; } }
.ecta__card::before {
  content: '';
  position: absolute;
  inset: -60px;
  border-radius: 80px;
  background: radial-gradient(ellipse at 30% 20%, rgba(74,154,106,0.15) 0%, transparent 50%), radial-gradient(ellipse at 70% 80%, rgba(74,154,106,0.1) 0%, transparent 50%);
  pointer-events: none;
  z-index: -1;
  animation: ectaAmbient 5s ease-in-out infinite alternate;
}
@keyframes ectaAmbient {
  0%   { opacity: 0.4; transform: scale(0.92) rotate(-1deg); }
  50%  { opacity: 1; transform: scale(1.04) rotate(0.5deg); }
  100% { opacity: 0.6; transform: scale(0.97) rotate(-0.5deg); }
}
.ecta__card-inner {
  background: linear-gradient(170deg, rgba(26,61,43,0.5) 0%, rgba(13,13,13,0.97) 40%, rgba(13,13,13,0.97) 60%, rgba(15,45,31,0.35) 100%);
  border-radius: 19px;
  padding: clamp(32px, 4vw, 48px) clamp(24px, 3vw, 40px);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 8px;
  position: relative;
  overflow: hidden;
  z-index: 3;
}
.ecta__card-inner::before {
  content: '';
  position: absolute;
  inset: 0;
  opacity: 0.03;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 128px 128px;
  pointer-events: none;
  mix-blend-mode: overlay;
}
.ecta__card-status {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px 6px 12px;
  background: rgba(74,154,106,0.1);
  border: 1px solid rgba(74,154,106,0.2);
  border-radius: 100px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--emergency-accent);
  margin-bottom: 12px;
  position: relative;
  z-index: 2;
}
.ecta__card-status .ecta__dot { width: 8px; height: 8px; }
.ecta__card-status .ecta__dot::after { inset: -4px; }
.ecta__phone {
  font-family: var(--font-body);
  font-size: clamp(1.85rem, 1.4rem + 2vw, 2.65rem);
  font-weight: 700;
  color: var(--emergency-text);
  text-decoration: none;
  letter-spacing: 0.04em;
  line-height: 1.1;
  padding: 4px 0;
  transition: all 0.3s ease;
  position: relative;
  z-index: 2;
}
.ecta__phone:hover { color: var(--emergency-accent); text-shadow: 0 0 30px var(--emergency-glow); }
.ecta__phone:focus-visible { outline: 2px solid var(--emergency-accent); outline-offset: 6px; border-radius: 4px; }
.ecta__phone::after {
  content: '';
  position: absolute;
  bottom: 0; left: 10%; right: 10%;
  height: 1px;
  background: var(--emergency-accent);
  opacity: 0.3;
  filter: blur(2px);
  transition: all 0.3s ease;
}
.ecta__phone:hover::after { opacity: 0.7; left: 0; right: 0; filter: blur(4px); }
.ecta__card-trust {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 600;
  color: var(--dark-text-muted);
  letter-spacing: 0.3px;
  position: relative;
  z-index: 2;
}
.ecta__card-trust svg { width: 12px; height: 12px; fill: var(--emergency-accent); flex-shrink: 0; }
.ecta__card-sublabel {
  font-size: 12px;
  font-weight: 600;
  color: var(--dark-text-muted);
  letter-spacing: 0.5px;
  margin-bottom: 12px;
  position: relative;
  z-index: 2;
}
.ecta__card-divider {
  width: 100%; height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--dark-border) 20%, var(--dark-border) 80%, transparent 100%);
  margin: 8px 0;
  position: relative;
  z-index: 2;
}
.ecta__card-msg-label { font-size: 13px; color: var(--dark-text-muted); margin-top: 8px; margin-bottom: 4px; position: relative; z-index: 2; }
.ecta__channels { display: flex; align-items: center; gap: 10px; margin-top: 4px; position: relative; z-index: 2; }
.ecta__channel {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: 10px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  color: var(--dark-text-secondary);
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.3s ease;
}
.ecta__channel:hover { background: rgba(74,154,106,0.1); border-color: rgba(74,154,106,0.3); color: var(--emergency-accent); transform: translateY(-1px); }
.ecta__channel:focus-visible { outline: 2px solid var(--emergency-accent); outline-offset: 2px; }
.ecta__channel svg { width: 18px; height: 18px; fill: currentColor; flex-shrink: 0; }
.ecta__encryption-note { display: flex; align-items: flex-start; gap: 6px; font-size: 11px; line-height: 1.5; color: var(--dark-text-muted); margin-top: 12px; position: relative; z-index: 2; }
.ecta__encryption-note svg { width: 14px; height: 14px; fill: var(--emergency-accent); flex-shrink: 0; margin-top: 1px; }
@media (prefers-reduced-motion: reduce) {
  .ecta__dot::after, .ecta__card-tilt::after, .ecta__card-tilt::before, .ecta__card::before { animation: none; }
  .ecta__card-tilt::after { opacity: 0.5; }
  .ecta__card-tilt::before { opacity: 0; }
  .ecta__card::before { opacity: 0.5; }
}
@media (forced-colors: active) {
  .ecta__card-tilt::after, .ecta__card-tilt::before { display: none; }
  .ecta__card-inner { border: 2px solid ButtonText; }
  .ecta__tag { border: 1px solid ButtonText; }
  .ecta__channel { border: 1px solid ButtonText; }
}
@media (max-width: 960px) {
  .ecta__grid { grid-template-columns: 1fr; gap: 40px; }
  .ecta__headline { max-width: 100%; }
  .ecta__desc { max-width: 100%; }
  .ecta__card { max-width: 480px; }
}
@media (max-width: 600px) {
  .ecta { padding: 48px 0; }
  .ecta__tags { gap: 5px; }
  .ecta__tag { padding: 5px 12px; font-size: 11px; }
  .ecta__channels { flex-direction: column; gap: 8px; width: 100%; }
  .ecta__channel { width: 100%; justify-content: center; min-height: 48px; padding: 14px 20px; }
  .ecta__card-inner { padding: 28px 20px; }
  .ecta__card::before { inset: -20px; border-radius: 40px; }
}

/* ============================================================
   EM-BANNER — Emergency Bottom Banner
   ============================================================ */
.em-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:#0D0D0D;border-top:1px solid rgba(255,255,255,0.06);transform:translateY(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);padding-bottom:env(safe-area-inset-bottom,0)}
.em-banner.is-visible{transform:translateY(0)}
.em-banner.is-hidden{transform:translateY(100%)}
.em-banner.is-dismissed{transform:translateY(100%)!important;pointer-events:none}
.em-banner__inner{max-width:1440px;margin:0 auto;padding:0 clamp(20px,12px + 3vw,96px);display:flex;align-items:center;justify-content:space-between;height:52px;gap:24px}
.em-banner__left{display:flex;align-items:center;gap:20px;min-width:0}
.em-banner__headline{font-size:13px;font-weight:600;color:#F8F6F2;white-space:nowrap;letter-spacing:.01em}
.em-banner__headline strong{color:#FF8A8A;font-weight:700}
.em-banner__sep{width:3px;height:3px;border-radius:50%;background:rgba(255,255,255,0.2);flex-shrink:0}
.em-banner__badges{display:flex;align-items:center;gap:6px}
.em-banner__badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:100px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.08);font-size:11px;font-weight:600;color:#B5AFA5;text-decoration:none;transition:all .25s ease;white-space:nowrap}
.em-banner__badge svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.em-banner__badge:hover{background:rgba(220,50,50,0.1);border-color:rgba(220,50,50,0.25);color:#F8F6F2}
.em-banner__badge:focus-visible{outline:2px solid #F5A623;outline-offset:2px}
.em-banner__right{flex-shrink:0}
.em-banner__cta{display:inline-flex;align-items:center;gap:8px;padding:10px 24px;border-radius:8px;font-size:13px;font-weight:700;text-decoration:none;color:#fff;transition:all .25s ease;white-space:nowrap;text-transform:uppercase;letter-spacing:.06em;position:relative;overflow:hidden;background:linear-gradient(90deg,#162040 0%,#0e0e18 40%,#0e0e18 60%,#2a1020 100%);border:1px solid rgba(255,255,255,0.06);box-shadow:0 0 35px rgba(60,120,255,0.2),0 4px 20px rgba(0,0,0,0.25);animation:ctaWashGlow 2.5s ease-in-out infinite}
.em-banner__cta::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.1),transparent);animation:ctaShimmer 3s ease-in-out infinite}
.em-banner__cta::before{content:'';position:absolute;inset:0;border-radius:inherit;animation:ctaWashSurface 2.5s ease-in-out infinite;z-index:0}
.em-banner__cta>*{position:relative;z-index:1}
.em-banner__cta:hover{transform:translateY(-1px)}
.em-banner__cta span{-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;background-image:linear-gradient(90deg,#6BA3FF 0%,#d0d8e8 30%,#e8e8e8 50%,#e8d0d0 70%,#FF6B6B 100%);background-size:200% 100%;animation:ctaTextSweep 2.5s ease-in-out infinite}
.em-banner__cta svg{width:14px;height:14px;stroke:#d0d8e8;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.em-banner__cta:focus-visible{outline:2px solid #F5A623;outline-offset:2px}
@keyframes ctaShimmer{0%,100%{left:-100%}50%{left:100%}}
@keyframes ctaWashGlow{0%,100%{box-shadow:0 0 35px rgba(60,120,255,0.25),0 4px 20px rgba(0,0,0,0.25)}50%{box-shadow:0 0 35px rgba(220,50,50,0.25),0 4px 20px rgba(0,0,0,0.25)}}
@keyframes ctaWashSurface{0%,100%{background:linear-gradient(90deg,rgba(60,120,255,0.4) 0%,rgba(60,120,255,0.2) 40%,transparent 100%)}50%{background:linear-gradient(90deg,transparent 0%,rgba(220,50,50,0.2) 60%,rgba(220,50,50,0.4) 100%)}}
@keyframes ctaTextSweep{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.em-banner__pulse{width:6px;height:6px;background:#DC3232;border-radius:50%;flex-shrink:0;animation:emPulse 2s ease-in-out infinite}
@keyframes emPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}
@media(max-width:768px){
  .em-banner.is-visible{transform:translateY(0)}
  .em-banner__inner{height:auto;padding:10px 12px;gap:8px}
  .em-banner__left{display:none}
  .em-banner__right{display:contents}
  .em-banner__mobile-bar{display:flex;width:100%;gap:8px;align-items:stretch}
  .em-banner__cta{flex:7;justify-content:center;padding:14px 16px;font-size:14px;border-radius:10px;min-height:48px}
  .em-banner__cta::after{animation-duration:2.5s}
  .em-banner__wa{flex:3;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a1a 0%,#111 100%);border-radius:10px;min-height:48px;text-decoration:none;transition:all .25s ease;border:1px solid rgba(37,211,102,0.2)}
  .em-banner__wa svg{width:22px;height:22px;fill:#25D366;transition:fill .25s ease}
  .em-banner__wa:hover{background:linear-gradient(135deg,#1e1e1e 0%,#151515 100%);border-color:rgba(37,211,102,0.4)}
  .em-banner__wa:hover svg{fill:#2EE876}
  .em-banner__wa:focus-visible{outline:2px solid #25D366;outline-offset:2px}
  .em-banner__close{display:flex}
}
@media(min-width:769px) and (max-width:1100px){.em-banner__badges,.em-banner__sep{display:none}}
@media(min-width:769px){.em-banner{will-change:transform}.em-banner__mobile-bar{display:contents}.em-banner__wa{display:none}}
.em-banner__close{display:none;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.1);cursor:pointer;flex-shrink:0;transition:background .2s ease;position:absolute;top:-14px;right:12px}
.em-banner__close svg{width:12px;height:12px;stroke:#B5AFA5;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.em-banner__close:hover{background:rgba(255,255,255,0.15)}
.em-banner__close:focus-visible{outline:2px solid #F5A623;outline-offset:2px}
@media(prefers-reduced-motion:reduce){.em-banner{transition:none}.em-banner__cta,.em-banner__cta::after,.em-banner__cta::before,.em-banner__cta span{animation:none}.em-banner__cta span{-webkit-text-fill-color:#F8F6F2}.em-banner__pulse{animation:none}}

/* ============================================================
   SECTION 10b — DOKUMENTY PRAWNE (Documents CTA on Homepage)
   Two-column editorial layout: intro left, document rows right.
   Mobile-first.
   ============================================================ */

.hdocs {
  background: var(--bg-secondary);
  padding: clamp(56px, 7vw, 112px) 0;
  position: relative;
  overflow: hidden;
}

.hdocs::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 120px;
  height: 1px;
  background: var(--bg-tertiary);
}

.hdocs__container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 clamp(20px, 12px + 3vw, 48px);
}

/* ── Layout — stacked mobile, two-col desktop ── */
.hdocs__layout {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

@media (min-width: 860px) {
  .hdocs__layout {
    flex-direction: row;
    align-items: start;
    gap: clamp(48px, 6vw, 80px);
  }
  .hdocs__intro {
    flex: 0 0 42%;
    max-width: 460px;
    position: sticky;
    top: 120px;
  }
  .hdocs__items {
    flex: 1 1 auto;
  }
}

/* ── Left column — editorial intro ── */
.hdocs__eyebrow {
  display: block;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 16px;
}

.hdocs__eyebrow::before {
  content: '';
  display: inline-block;
  width: 24px;
  height: 1px;
  background: var(--accent);
  vertical-align: middle;
  margin-right: 10px;
}

.hdocs__headline {
  font-family: var(--font-display);
  font-size: clamp(1.85rem, 1.2rem + 3vw, 3rem);
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.12;
  margin: 0 0 20px;
}

.hdocs__headline em {
  font-style: italic;
  color: var(--accent);
}

.hdocs__lead {
  font-family: var(--font-body);
  font-size: clamp(14.5px, 1vw, 16px);
  color: var(--text-secondary);
  line-height: 1.7;
  margin: 0 0 28px;
  max-width: 44ch;
}

/* ── Trust indicators ── */
.hdocs__trust {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 28px;
}

.hdocs__trust-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-tertiary);
}

.hdocs__trust-item svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  stroke: var(--accent);
}

/* ── Action links ── */
.hdocs__actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.hdocs__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  transition: gap 0.3s ease, color 0.3s ease;
  width: fit-content;
}

.hdocs__link:hover {
  gap: 12px;
  color: var(--accent-hover);
}

.hdocs__link svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex-shrink: 0;
}

.hdocs__link--subtle {
  color: var(--text-tertiary);
  font-weight: 500;
  font-size: 13px;
}

.hdocs__link--subtle:hover {
  color: var(--accent);
}

.hdocs__actions-sep {
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--text-muted);
  padding-left: 1px;
}

/* ── Right column — document rows ── */
.hdocs__items {
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* ── Individual row ── */
.hdocs__row {
  display: grid;
  grid-template-columns: 48px 1fr auto;
  gap: 16px;
  align-items: center;
  padding: 22px 0;
  border-bottom: 1px solid var(--bg-tertiary);
  text-decoration: none;
  color: inherit;
  transition: background 0.3s ease, padding 0.3s ease;
  border-radius: 0;
  position: relative;
}

.hdocs__row:first-child {
  border-top: 1px solid var(--bg-tertiary);
}

.hdocs__row:hover {
  background: var(--bg-elevated);
  padding-left: 16px;
  padding-right: 16px;
  border-radius: 12px;
  border-color: transparent;
}

.hdocs__row:hover + .hdocs__row {
  border-top-color: transparent;
}

/* icon box */
.hdocs__row-icon {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--accent-bg-solid);
  border: 1px solid var(--accent-border-solid);
  border-radius: 12px;
  flex-shrink: 0;
  transition: background 0.3s ease, border-color 0.3s ease;
}

.hdocs__row:hover .hdocs__row-icon {
  background: var(--accent);
  border-color: var(--accent);
}

.hdocs__row-icon svg {
  width: 22px;
  height: 22px;
  stroke: var(--accent);
  transition: stroke 0.3s ease;
}

.hdocs__row:hover .hdocs__row-icon svg {
  stroke: #fff;
}

/* text body */
.hdocs__row-body {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}

.hdocs__row-title {
  font-family: var(--font-display);
  font-size: clamp(1.05rem, 1.2vw, 1.2rem);
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.25;
}

.hdocs__row-desc {
  font-family: var(--font-body);
  font-size: 13.5px;
  color: var(--text-tertiary);
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* price + arrow */
.hdocs__row-meta {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}

.hdocs__row-price {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--accent-champagne);
  white-space: nowrap;
  padding: 4px 12px;
  background: rgba(197, 185, 154, 0.12);
  border-radius: 20px;
}

.hdocs__row-price--free {
  color: var(--accent);
  background: var(--accent-bg);
}

.hdocs__row-arrow {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1px solid var(--bg-tertiary);
  transition: border-color 0.3s ease, transform 0.3s ease, background 0.3s ease;
}

.hdocs__row-arrow svg {
  width: 16px;
  height: 16px;
  stroke: var(--text-muted);
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: stroke 0.3s ease;
}

.hdocs__row:hover .hdocs__row-arrow {
  border-color: var(--accent);
  background: var(--accent);
  transform: translateX(2px);
}

.hdocs__row:hover .hdocs__row-arrow svg {
  stroke: #fff;
}

.hdocs__row:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: 12px;
}

/* ── Mobile adjustments ── */
@media (max-width: 520px) {
  .hdocs__row {
    grid-template-columns: 40px 1fr auto;
    gap: 12px;
    padding: 18px 0;
  }

  .hdocs__row-icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
  }

  .hdocs__row-icon svg {
    width: 18px;
    height: 18px;
  }

  .hdocs__row-desc {
    -webkit-line-clamp: 1;
  }

  .hdocs__row-arrow {
    width: 28px;
    height: 28px;
  }

  .hdocs__row-arrow svg {
    width: 14px;
    height: 14px;
  }
}

/* ── Scroll Reveal ── */
.hdocs-reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}

.hdocs-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.hdocs__items.hdocs-reveal {
  transition-delay: 0.15s;
}

/* row stagger — applied via JS transition-delay */
.hdocs__row {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.5s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.5s cubic-bezier(0.16, 1, 0.3, 1),
              background 0.3s ease,
              padding 0.3s ease;
}

.hdocs__items.is-visible .hdocs__row {
  opacity: 1;
  transform: translateY(0);
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  .hdocs-reveal,
  .hdocs__row {
    opacity: 1;
    transform: none;
    transition: background 0.3s ease, padding 0.3s ease;
  }
}

/* ============================================================
   SECTION 10 — BAZA WIEDZY (Knowledge Base / Blog Cards)
   ============================================================ */

.knowledge {
  background: var(--bg-primary);
  padding: clamp(72px, 7vw, 128px) 0;
  position: relative;
}

.knowledge::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 120px;
  height: 1px;
  background: var(--bg-tertiary);
}

.knowledge__header {
  text-align: center;
  margin-bottom: 48px;
}

.knowledge__eyebrow {
  display: block;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
}

.knowledge__eyebrow::before {
  content: '';
  display: block;
  width: 24px;
  height: 1px;
  background: linear-gradient(var(--accent), transparent);
  margin: 0 auto 14px;
}

.knowledge__headline {
  font-family: var(--font-display);
  font-size: clamp(2rem, 1.4rem + 3vw, 3.25rem);
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.15;
}

.knowledge__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  max-width: 1200px;
  margin: 0 auto;
}

@media (min-width: 640px) {
  .knowledge__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .knowledge__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.knowledge-card {
  background: var(--bg-elevated);
  border: 1px solid var(--bg-tertiary);
  border-radius: 14px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1),
              box-shadow 0.35s cubic-bezier(0.16, 1, 0.3, 1),
              border-color 0.35s ease;
}

.knowledge-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: var(--accent-border-solid);
}

.knowledge-card:active {
  transform: scale(0.985);
}

@media (hover: hover) {
  .knowledge-card:active {
    transform: translateY(-4px);
  }
}

.knowledge-card__figure {
  margin: 0;
  position: relative;
  overflow: hidden;
  aspect-ratio: 16 / 9;
  background: var(--bg-tertiary);
}

.knowledge-card__img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.knowledge-card:hover .knowledge-card__img {
  transform: scale(1.03);
}

.knowledge-card__category {
  position: absolute;
  bottom: 12px;
  left: 12px;
  display: inline-flex;
  align-items: center;
  padding: 5px 14px;
  border-radius: 100px;
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  background: var(--bg-elevated);
  color: var(--accent);
  border: 1px solid var(--accent-border-solid);
  white-space: nowrap;
}

.knowledge-card__body {
  padding: 24px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.knowledge-card__title {
  font-family: var(--font-body);
  font-size: clamp(1rem, 0.95rem + 0.3vw, 1.15rem);
  font-weight: 700;
  line-height: 1.35;
  margin-bottom: 10px;
}

.knowledge-card__title-link {
  color: var(--text-primary);
  text-decoration: none;
  transition: color 0.25s ease;
  display: block;
}

.knowledge-card__title-link:hover {
  color: var(--accent);
}

.knowledge-card__title-link:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
  border-radius: 4px;
}

.knowledge-card__excerpt {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 400;
  color: var(--text-tertiary);
  line-height: 1.6;
  margin-bottom: 16px;
  flex: 1;
}

.knowledge-card__meta {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  color: var(--text-muted);
}

.knowledge-card__meta svg {
  width: 14px;
  height: 14px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex-shrink: 0;
}

/* Read more link */
.knowledge-card__read-more {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 12px;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--accent, #b89a5a);
  text-decoration: none;
  transition: gap 0.25s ease;
}

.knowledge-card__read-more svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  transition: transform 0.25s ease;
}

.knowledge-card__read-more:hover {
  gap: 6px;
}

.knowledge-card__read-more:hover svg {
  transform: translateX(2px);
}

.knowledge__cta {
  text-align: center;
  margin-top: 40px;
}

.knowledge__cta-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  transition: color 0.3s ease;
}

.knowledge__cta-link:hover {
  color: var(--accent-hover);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: var(--accent-border-solid);
}

.knowledge__cta-link:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
  border-radius: 4px;
}

.knowledge__cta-link svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: transform 0.3s ease;
}

.knowledge__cta-link:hover svg {
  transform: translateX(3px);
}

.knowledge-reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}

.knowledge-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ============================================================
   SECTION 12 — ZASIĘG GEOGRAFICZNY (Geo)
   ============================================================ */

.geo {
  background: var(--bg-secondary);
  padding: clamp(48px, 6vw, 80px) 0;
  position: relative;
}

.geo__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}

.geo__eyebrow {
  display: block;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent, #2E6B47);
  margin-bottom: 12px;
}

.geo__headline {
  font-family: 'Space Grotesk', sans-serif;
  font-size: clamp(26px, 3vw, 36px);
  font-weight: 700;
  line-height: 1.2;
  color: var(--text-primary);
  margin: 0 0 16px;
}

.geo__desc {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 16px;
  line-height: 1.6;
  color: var(--text-secondary);
  margin: 0 0 24px;
}

.geo__local {
  border-left: 3px solid var(--accent, #2E6B47);
  padding-left: 16px;
  margin-top: 24px;
}

.geo__local-heading {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 16px;
  font-weight: 600;
  color: var(--text-primary);
  display: block;
  margin-bottom: 4px;
}

.geo__local-desc {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 15px;
  line-height: 1.5;
  color: var(--text-secondary);
  margin: 0;
}

.geo__map {
  display: flex;
  align-items: center;
  justify-content: center;
}

.geo__map img,
.geo__map svg {
  max-width: 100%;
  height: auto;
}

.geo__map-placeholder {
  width: 100%;
  aspect-ratio: 1;
  background: var(--bg-tertiary, #E4E0D9);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 14px;
  color: var(--text-tertiary);
}

@media (max-width: 768px) {
  .geo {
    padding: 48px 16px;
  }
  .geo__grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
}

/* ============================================================
   FAQ SECTION — accordion + sticky CTA sidebar
   ============================================================ */

.faq {
  background: var(--bg-primary);
  padding: clamp(64px, 6vw, 112px) 0;
  position: relative;
}

/* subtle top border */
.faq::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: min(90%, 1200px);
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--bg-tertiary), transparent);
}

/* ── Header ── */
.faq__header {
  margin-bottom: clamp(36px, 4vw, 56px);
}

.faq__eyebrow {
  display: block;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
}

.faq__eyebrow::before {
  content: '';
  display: inline-block;
  width: 24px;
  height: 1px;
  background: linear-gradient(90deg, var(--accent), transparent);
  vertical-align: middle;
  margin-right: 10px;
}

.faq__headline {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 1.2rem + 2.5vw, 2.75rem);
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.2;
  max-width: 600px;
}

/* ── Two-column layout ── */
.faq__grid {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: clamp(32px, 4vw, 64px);
  align-items: start;
}

/* ── Accordion ── */
.faq__accordion {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.faq__item {
  border-bottom: 1px solid var(--bg-tertiary);
}

.faq__item:first-child {
  border-top: 1px solid var(--bg-tertiary);
}

.faq__question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  width: 100%;
  padding: 22px 0;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.4;
  transition: color 0.25s ease;
}

.faq__question:hover {
  color: var(--accent);
}

.faq__question:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 4px;
  border-radius: 4px;
}

/* ── Plus/minus icon ── */
.faq__icon {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1px solid var(--bg-tertiary);
  transition: background 0.3s ease, border-color 0.3s ease, transform 0.3s ease;
}

.faq__icon svg {
  width: 14px;
  height: 14px;
  stroke: var(--text-tertiary);
  stroke-width: 2;
  stroke-linecap: round;
  fill: none;
  transition: stroke 0.3s ease;
}

/* vertical line of the plus rotates to form minus */
.faq__icon svg line:first-child {
  transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  transform-origin: center;
}

.faq__question[aria-expanded="true"] .faq__icon {
  background: var(--accent-bg);
  border-color: var(--accent-border-solid);
}

.faq__question[aria-expanded="true"] .faq__icon svg {
  stroke: var(--accent);
}

.faq__question[aria-expanded="true"] .faq__icon svg line:first-child {
  transform: rotate(90deg);
}

/* ── Answer panel ── */
.faq__answer {
  overflow: hidden;
  transition: max-height 0.4s cubic-bezier(0.16, 1, 0.3, 1),
              opacity 0.3s ease;
  max-height: 0;
  opacity: 0;
}

.faq__answer[hidden] {
  display: block;
  max-height: 0;
  opacity: 0;
  visibility: hidden;
}

.faq__answer.is-open {
  opacity: 1;
  visibility: visible;
}

.faq__answer-inner {
  padding: 0 0 24px;
}

.faq__answer-inner p {
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 400;
  color: var(--text-secondary);
  line-height: 1.7;
  max-width: 640px;
}

.faq__answer-inner a {
  color: var(--accent);
  font-weight: 500;
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: var(--accent-border-solid);
  transition: text-decoration-color 0.2s ease;
}

.faq__answer-inner a:hover {
  text-decoration-color: var(--accent);
}

/* ── Sticky sidebar ── */
.faq__sidebar {
  position: sticky;
  top: 120px;
}

.faq__sidebar-card {
  background: var(--bg-elevated);
  border: 1px solid var(--bg-tertiary);
  border-radius: 16px;
  padding: 36px 28px;
  text-align: center;
  box-shadow: var(--shadow-sm);
  transition: box-shadow 0.35s ease;
}

.faq__sidebar-card:hover {
  box-shadow: var(--shadow-md);
}

.faq__sidebar-icon {
  width: 48px;
  height: 48px;
  margin: 0 auto 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  background: var(--accent-bg);
  border: 1px solid var(--accent-border-solid);
}

.faq__sidebar-icon svg {
  width: 22px;
  height: 22px;
  stroke: var(--accent);
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  fill: none;
}

.faq__sidebar-headline {
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.25;
  margin-bottom: 10px;
}

.faq__sidebar-text {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text-tertiary);
  line-height: 1.6;
  margin-bottom: 24px;
}

.faq__sidebar-btn {
  width: 100%;
  justify-content: center;
  padding: 14px 24px;
}

.faq__sidebar-btn svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.faq__sidebar-meta {
  margin-top: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--text-muted);
  font-weight: 500;
}

.faq__sidebar-sep {
  font-size: 12px;
  color: var(--bg-tertiary);
}

/* ── Scroll reveal ── */
.faq-reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}

.faq-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ── Responsive: tablet ── */
@media (max-width: 1024px) {
  .faq__grid {
    grid-template-columns: 1fr 280px;
    gap: 32px;
  }
}

/* ── Responsive: mobile ── */
@media (max-width: 767px) {
  .faq__grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .faq__sidebar {
    position: static;
    order: -1;
  }

  .faq__question {
    font-size: 15px;
    padding: 18px 0;
  }
}


/* ============================================================
   SECTION 12 — FINAL CTA
   ============================================================ */

.fcta {
  background: var(--dark-bg);
  padding: clamp(48px, 5vw, 80px) 0;
  position: relative;
  overflow: hidden;
  border-top: 1px solid var(--dark-border-subtle);
}

/* radial glow behind the left column */
.fcta::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 25%;
  transform: translate(-50%, -50%);
  width: 600px;
  height: 400px;
  background: radial-gradient(ellipse, rgba(74,154,106,0.07) 0%, transparent 70%);
  pointer-events: none;
}

/* two-column grid */
.fcta__grid {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: clamp(40px, 5vw, 80px);
  align-items: center;
}

/* ── Left: content ── */
.fcta__content {
  position: relative;
}

.fcta__eyebrow {
  display: block;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--accent-light);
  margin-bottom: 14px;
}

.fcta__eyebrow::before {
  content: '';
  display: inline-block;
  width: 24px;
  height: 1px;
  background: var(--accent-light);
  vertical-align: middle;
  margin-right: 10px;
}

.fcta__headline {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 1.3rem + 2.5vw, 2.75rem);
  font-weight: 600;
  color: var(--dark-text);
  line-height: 1.15;
  margin-bottom: 14px;
}

.fcta__sub {
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 400;
  color: var(--dark-text-secondary);
  line-height: 1.6;
  margin-bottom: 24px;
  max-width: 440px;
}

/* trust bar: left-aligned under text */
.fcta__trust {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.fcta__trust-item {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  color: var(--dark-text-muted);
  letter-spacing: 0.3px;
}

.fcta__trust-sep {
  color: var(--dark-border);
  font-size: 12px;
}

/* ── Right: action ── */
.fcta__action {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 20px;
}

/* phone button: large, full-width within column */
.fcta__phone {
  font-size: 20px;
  padding: 18px 44px;
  border-radius: 12px;
  justify-content: center;
}

.fcta__phone svg {
  width: 22px;
  height: 22px;
}

/* alternative channels */
.fcta__alt {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}

.fcta__alt-label {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--dark-text-muted);
}

.fcta__channels {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
}

.fcta__channel {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  flex: 1;
  padding: 8px 16px;
  border-radius: 8px;
  border: 1px solid var(--dark-border);
  background: transparent;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--dark-text-secondary);
  text-decoration: none;
  transition: border-color 0.25s ease, color 0.25s ease, background 0.25s ease;
}

.fcta__channel:hover {
  border-color: var(--accent-light);
  color: var(--accent-light);
  background: rgba(74,154,106,0.06);
}

.fcta__channel:focus-visible {
  outline: 2px solid var(--accent-light);
  outline-offset: 2px;
}

.fcta__channel svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

/* scroll reveal */
.fcta-reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}

.fcta-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ── Mobile: stack columns ── */
@media (max-width: 767px) {
  .fcta__grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .fcta__content {
    text-align: center;
  }

  .fcta__sub {
    max-width: none;
  }

  .fcta__trust {
    justify-content: center;
  }

  .fcta__channels {
    flex-wrap: wrap;
    justify-content: center;
  }
}

/* ============================================================
   PRZYKŁADY SPRAW (Case Studies)
   ============================================================ */

/* ── Section ── */
.cases {
  width: 100%;
  background: var(--bg-secondary);
  padding: clamp(72px, 7vw, 128px) 0;
}

/* ── Section header ── */
.cases__header {
  text-align: center;
  margin-bottom: 48px;
}

.cases__eyebrow {
  display: block;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
}

.cases__eyebrow::before {
  content: '';
  display: block;
  width: 24px;
  height: 1px;
  background: linear-gradient(var(--accent), transparent);
  margin: 0 auto 14px;
}

.cases__headline {
  font-family: var(--font-display);
  font-size: clamp(2rem, 1.4rem + 3vw, 3.25rem);
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.15;
}

/* ── Cards list ── */
.cases__list {
  display: flex;
  flex-direction: column;
  gap: 22px;
  max-width: 1200px;
  margin: 0 auto;
}

/* ── Card shell ── */
.case-card {
  position: relative;
  background: var(--bg-elevated);
  border: 1px solid var(--bg-tertiary);
  border-radius: 14px;
  box-shadow: var(--shadow-sm);
  padding: clamp(28px, 3vw, 44px);
  overflow: hidden;
  transition: background 0.35s ease, border-color 0.35s ease, transform 0.1s ease;
  perspective: 1000px;
}

.case-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--accent), transparent 80%);
  opacity: 0;
  transition: opacity 0.35s ease;
}

/* inner glow, positioned via JS custom properties */
.case-card::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: radial-gradient(600px circle at var(--mouse-x, 50%) var(--mouse-y, 50%), rgba(46,107,71,0.04), transparent 60%);
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.35s ease;
}

.case-card:hover {
  background: rgba(46,107,71,0.02);
  border-color: var(--accent-border-solid);
}

.case-card:hover::before {
  opacity: 0.4;
}

.case-card:hover::after {
  opacity: 1;
}

/* touch feedback on mobile */
.case-card:active {
  transform: scale(0.995);
}

@media (hover: hover) {
  .case-card:active {
    transform: none;
  }
}

/* ── Emergency card variant (Adwokat 24) ── */
.case-card--emergency {
  background: var(--emergency-bg);
  border-color: #1a1a1a;
  box-shadow: 0 4px 24px rgba(0,0,0,0.12);
}

.case-card--emergency::before {
  background: linear-gradient(90deg, var(--emergency-accent), transparent 80%);
  opacity: 0.5;
}

.case-card--emergency::after {
  background: radial-gradient(600px circle at var(--mouse-x, 50%) var(--mouse-y, 50%), rgba(74,154,106,0.06), transparent 60%);
}

.case-card--emergency:hover {
  background: #111;
  border-color: #2a2a2a;
}

.case-card--emergency:hover::before {
  opacity: 0.8;
}

.case-card--emergency .case-card__title-link {
  color: var(--text-inverse);
}

.case-card--emergency .case-card__title-link:hover {
  color: var(--emergency-accent);
}

.case-card--emergency .case-card__title-link:focus-visible {
  box-shadow: 0 0 0 3px rgba(74,154,106,0.3);
}

.case-card--emergency .case-card__outcome-text {
  color: var(--emergency-accent);
}

.case-card--emergency .case-card__outcome-bar {
  background: var(--emergency-accent);
}

.case-card--emergency .case-card__desc {
  color: #A0A0A0;
}

.case-card--emergency .case-card__quote {
  border-left-color: #2a2a2a;
}

.case-card--emergency .case-card__quote p {
  color: #8A8A8A;
}

.case-card--emergency .case-card__quote-mark {
  color: var(--emergency-accent);
}

.case-card--emergency .case-card__quote cite {
  color: #6B6B6B;
}

.case-card--emergency .case-card__result-label {
  color: #6B6B6B;
}

.case-card--emergency .case-card__result-text {
  color: var(--text-inverse);
}

.case-card--emergency .case-card__spec-link {
  color: var(--emergency-accent);
}

.case-card--emergency .case-card__spec-link:hover {
  color: #5AAF7A;
  text-decoration-color: rgba(74,154,106,0.3);
}

.case-card--emergency .case-card__contact-link {
  color: #6B6B6B;
}

.case-card--emergency .case-card__contact-link:hover {
  color: var(--emergency-accent);
}

.case-card--emergency .case-card__footer-sep {
  color: #2a2a2a;
}

/* ── Card grid ── */
.case-card__grid {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: clamp(28px, 3vw, 48px);
  align-items: start;
}

.case-card__left {
  display: flex;
  flex-direction: column;
}

.case-card__right {
  display: flex;
  flex-direction: column;
}

.case-card__left-panel {
  display: flex;
  flex-direction: column;
}

/* ── Left column: icon ── */
.case-card__icon {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  background: var(--accent-bg-solid);
  border: 1px solid var(--accent-border-solid);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
  flex-shrink: 0;
}

.case-card--emergency .case-card__icon {
  background: rgba(74,154,106,0.1);
  border-color: rgba(74,154,106,0.2);
}

.case-card__icon svg {
  width: 22px;
  height: 22px;
  stroke: var(--accent);
  fill: none;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.case-card--emergency .case-card__icon svg {
  stroke: var(--emergency-accent);
}

/* Adwokat 24: pulsating dot instead of icon box */
.case-card__icon--emergency {
  width: auto;
  height: auto;
  min-height: 48px;
  display: flex;
  align-items: center;
  margin-bottom: 16px;
  flex-shrink: 0;
}

/* reuse global .pulse-dot where possible, but scoped variant
   for cases section to avoid conflicts with nav pulse-dot */
.cases-pulse-dot {
  display: inline-block;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--emergency-accent);
  position: relative;
  flex-shrink: 0;
}

.cases-pulse-dot::after {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  background: var(--emergency-accent);
  opacity: 0;
  animation: cases-pulse 2s ease-in-out infinite;
}

.cases-pulse-dot--sm {
  width: 6px;
  height: 6px;
}

.cases-pulse-dot--sm::after {
  inset: -3px;
}

@keyframes cases-pulse {
  0%, 100% { opacity: 0; transform: scale(0.8); }
  50% { opacity: 0.4; transform: scale(1.6); }
}

/* ── Left column: badge ── */
.case-card__badge {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  gap: 6px;
  padding: 6px 16px;
  border-radius: 100px;
  font-size: 11px;
  font-weight: 600;
  margin-bottom: 16px;
  white-space: nowrap;
}

.case-card__badge--standard {
  background: var(--accent-bg-solid);
  color: var(--accent);
  border: 1px solid var(--accent-border-solid);
}

.case-card--emergency .case-card__badge--standard {
  background: rgba(74,154,106,0.1);
  border-color: rgba(74,154,106,0.2);
  color: var(--emergency-accent);
}

.case-card__badge--emergency {
  background: var(--emergency-accent);
  color: #fff;
  border: 1px solid var(--emergency-accent);
}

/* ── Left column: result ── */
.case-card__result-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 6px;
}

.case-card__result-text {
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.4;
}

/* ── Right column: title (as link) ── */
.case-card__title {
  margin-bottom: 16px;
}

.case-card__title-link {
  font-family: var(--font-body);
  font-size: clamp(1.15rem, 1rem + 0.5vw, 1.4rem);
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.3;
  text-decoration: none;
  transition: color 0.25s ease;
  display: block;
}

.case-card__title-link:hover {
  color: var(--accent);
}

.case-card__title-link:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
  border-radius: 4px;
}

/* ── Right column: accented outcome block ──
   Hidden on desktop (left panel shows result).
   Shown on mobile where left panel is gone. */
.case-card__outcome {
  display: none;
  align-items: stretch;
  margin-bottom: 16px;
}

.case-card__outcome-bar {
  width: 3px;
  background: var(--accent);
  border-radius: 2px;
  margin-right: 14px;
  flex-shrink: 0;
  transform-origin: bottom;
  transform: scaleY(0);
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1) 0.3s;
}

.cases-reveal.is-visible .case-card__outcome-bar {
  transform: scaleY(1);
}

.case-card__outcome-text {
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 700;
  color: var(--accent);
  line-height: 1.4;
}

/* ── Right column: description ── */
.case-card__desc {
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 400;
  color: var(--text-secondary);
  line-height: 1.7;
  margin-bottom: 20px;
}

/* ── Right column: client quote ── */
.case-card__quote {
  margin-bottom: 20px;
  padding-left: 18px;
  border-left: 1px solid var(--bg-tertiary);
}

.case-card__quote p {
  font-family: var(--font-display);
  font-size: clamp(1rem, 0.95rem + 0.3vw, 1.15rem);
  font-style: italic;
  font-weight: 400;
  color: var(--text-tertiary);
  line-height: 1.6;
}

.case-card__quote-mark {
  font-family: var(--font-display);
  font-size: 24px;
  color: var(--accent);
  font-style: normal;
}

.case-card__quote cite {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  color: var(--text-muted);
  font-style: normal;
  margin-left: 4px;
}

/* ── Right column: footer ── */
.case-card__footer {
  display: flex;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}

.case-card__spec-link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  transition: color 0.3s ease;
}

.case-card__spec-link:hover {
  color: var(--accent-hover);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: var(--accent-border-solid);
}

.case-card__spec-link .arrow {
  display: inline-block;
  transition: transform 0.3s ease;
}

.case-card__spec-link:hover .arrow {
  transform: translateX(3px);
}

.case-card__footer-sep {
  color: var(--bg-tertiary);
  font-size: 14px;
  user-select: none;
}

.case-card__contact-link {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-muted);
  text-decoration: none;
  transition: color 0.3s ease;
}

.case-card__contact-link:hover {
  color: var(--accent);
}

/* ── Scroll-reveal ── */
.cases-reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}

.cases-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ── Tablet ── */
@media (max-width: 1023px) and (min-width: 768px) {
  .case-card__grid {
    grid-template-columns: 220px 1fr;
    gap: 24px;
  }
}

/* ── Mobile ── */
@media (max-width: 767px) {
  .case-card__grid {
    grid-template-columns: 1fr;
  }

  .case-card {
    padding: 24px 20px;
  }

  .cases__list {
    gap: 16px;
  }

  .case-card__left,
  .case-card__right {
    display: contents;
  }

  .case-card__left-panel {
    display: contents;
  }

  .case-card__outcome {
    display: flex;
  }

  .case-card__title    { order: 1; }
  .case-card__badge    { order: 2; justify-self: start; }
  .case-card__outcome  { order: 3; }
  .case-card__desc     { order: 4; }
  .case-card__quote    { order: 5; }
  .case-card__footer   { order: 6; }

  .case-card__icon,
  .case-card__icon--emergency,
  .case-card__result-label,
  .case-card__result-text {
    display: none;
  }
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  .cases-reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .cases-pulse-dot::after {
    animation: none;
  }

  .case-card__outcome-bar {
    transform: none;
    transition: none;
  }
}

/* ============================================================
   SECTION 8 — ZNANY Z (Media Mentions)
   Loga zaprojektowane w czystym CSS/typografii.
   ============================================================ */

/* ── Section wrapper ──
   Shares --bg-primary with reviews above so they read as one block.
   Top padding reduced — bottom padding of reviews provides the gap. */
.media {
  background: var(--bg-primary);
  padding: 0 0 clamp(64px, 8vw, 112px);
}

/* ── Subtle divider from reviews above ── */
.media::before {
  content: '';
  display: block;
  max-width: 120px;
  height: 1px;
  background: var(--bg-tertiary);
  margin: 0 auto clamp(48px, 6vw, 80px);
}

/* ── Header ── */
.media__header {
  text-align: center;
  margin-bottom: var(--space-6);
}

.media__eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--space-2);
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.media__headline {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 2.5vw, 2.2rem);
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.3;
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.6s ease 0.05s, transform 0.6s ease 0.05s;
}

/* ── Logo bar ── */
.media__logos {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: clamp(28px, 5vw, 64px);
  margin-bottom: var(--space-8);
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.6s ease 0.1s, transform 0.6s ease 0.1s;
}

.media__logo-link {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-1) var(--space-2);
  border-radius: 8px;
  transition: transform 0.35s ease;
}

.media__logo-link:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 4px;
}

.media__logo-link:hover {
  transform: scale(1.06);
}

/* ── Logo text base ── */
.media__logo-text {
  display: inline-flex;
  align-items: center;
  user-select: none;
  white-space: nowrap;
  line-height: 1;
  color: var(--text-muted);
  transition: color 0.4s ease;
}

/* ============================================================
   Logo designs
   ============================================================ */

/* ── FAKT ──
   Tabloidowy, gruby, uppercase, rozstrzelony */
.media__logo--fakt {
  font-family: 'Space Grotesk', Impact, sans-serif;
  font-size: clamp(1.25rem, 1.8vw, 1.55rem);
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.media__logo-link:hover .media__logo--fakt {
  color: #D32F2F;
}

/* ── naTemat ──
   "na" lekkie, "Temat" pogrubione */
.media__logo--natemat {
  font-family: 'Space Grotesk', sans-serif;
  font-size: clamp(1.25rem, 1.9vw, 1.6rem);
  font-weight: 700;
  letter-spacing: -0.01em;
}

.media__logo-light {
  font-weight: 300;
  opacity: 0.65;
  transition: opacity 0.4s ease;
}

.media__logo-link:hover .media__logo--natemat {
  color: #1A1A2E;
}

.media__logo-link:hover .media__logo-light {
  opacity: 0.5;
}

/* ── Onet ──
   Duże "O", reszta lowercase, żółty hover */
.media__logo--onet {
  font-family: 'Space Grotesk', sans-serif;
  font-size: clamp(1.4rem, 2.1vw, 1.8rem);
  font-weight: 700;
  letter-spacing: -0.03em;
}

.media__logo-link:hover .media__logo--onet {
  color: #E8A800;
}

/* ── Prawo.pl ──
   Profesjonalny serif, ".pl" mniejsze */
.media__logo--prawo {
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 2.1vw, 1.8rem);
  font-weight: 700;
  letter-spacing: 0.01em;
}

.media__logo-dot {
  font-weight: 500;
  font-size: 0.75em;
  opacity: 0.6;
  transition: opacity 0.4s ease;
}

.media__logo-link:hover .media__logo--prawo {
  color: #1B5E20;
}

.media__logo-link:hover .media__logo-dot {
  opacity: 0.85;
}

/* ── Polskie Radio ──
   Elegancki, rozstrzelony uppercase, klasyczny */
.media__logo--trojka {
  font-family: 'Space Grotesk', sans-serif;
  font-size: clamp(0.85rem, 1.2vw, 1.05rem);
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.media__logo-link:hover .media__logo--trojka {
  color: #1565C0;
}

/* ── Bottom: CTA centered ── */
.media__bottom {
  text-align: center;
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.6s ease 0.15s, transform 0.6s ease 0.15s;
}

/* ── CTA link ── */
.media__cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--accent);
  white-space: nowrap;
  padding-top: 4px;
  transition: color 0.3s ease, gap 0.3s ease;
  flex-shrink: 0;
}

.media__cta svg {
  width: 18px;
  height: 18px;
  transition: transform 0.3s ease;
}

.media__cta:hover {
  color: var(--accent-hover);
  gap: 12px;
}

.media__cta:hover svg {
  transform: translateX(2px);
}

.media__cta:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 4px;
  border-radius: 4px;
}

/* ── Reveal animation ── */
.media-reveal.is-visible .media__eyebrow,
.media-reveal.is-visible .media__headline,
.media-reveal.is-visible .media__logos,
.media-reveal.is-visible .media__bottom {
  opacity: 1;
  transform: translateY(0);
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  .media__eyebrow,
  .media__headline,
  .media__logos,
  .media__bottom {
    opacity: 1;
    transform: none;
    transition: none;
  }
  .media__logo-text,
  .media__logo-link,
  .media__logo-light,
  .media__logo-dot,
  .media__cta,
  .media__cta svg {
    transition: none;
  }
}

/* ── Responsive: mobile ── */
@media (max-width: 600px) {
  .media__logos {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-3);
    max-width: 340px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: var(--space-6);
  }

  .media__logo-link {
    justify-self: center;
  }

  .media__logo-link:last-child {
    grid-column: 1 / -1;
  }

}

/* ============================================================
   FOOTER — Kancelaria Adwokacka Oskar Skoczylas
   Uses design tokens from style.css
   ============================================================ */

/* Main footer wrapper */
.site-footer {
  background: var(--dark-bg-alt);
  color: var(--dark-text);
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.7;
  padding-top: var(--space-10);
}

/* Logo replaces heading in contact column */
.footer__logo {
  height: 42px;
  width: auto;
  margin-bottom: var(--space-3);
}

/* Four-column grid */
.footer__grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr 1fr 1fr;
  gap: var(--space-8);
  padding-bottom: 0;
}

/* Column headings */
.footer__heading {
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 600;
  color: var(--dark-text);
  margin-bottom: var(--space-3);
  letter-spacing: 0.01em;
}

/* Contact address block */
.footer__address {
  font-style: normal;
  margin-bottom: var(--space-3);
}

.footer__address-line {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  margin-bottom: var(--space-1);
  color: var(--dark-text-secondary);
}

.footer__address-line--name {
  color: var(--dark-text);
  font-weight: 500;
  margin-bottom: var(--space-1);
}

.footer__address-line--legal {
  font-size: 12px;
  color: var(--dark-text-muted);
  margin-top: 4px;
}

.footer__icon {
  width: 16px;
  text-align: center;
  color: var(--accent-light);
  flex-shrink: 0;
}

/* Links */
.footer__link {
  color: var(--dark-text-secondary);
  transition: color 0.2s ease;
}

.footer__link:hover,
.footer__link:focus-visible {
  color: var(--accent-light);
}

.footer__link--external {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.footer__external-icon {
  font-size: 10px;
  opacity: 0.6;
}

/* Messenger icons */
.footer__messengers {
  display: flex;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}

.footer__messenger-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 8px;
  border: 1px solid var(--dark-border);
  color: var(--dark-text-secondary);
  font-size: 18px;
  transition: all 0.2s ease;
}

.footer__messenger-link:hover,
.footer__messenger-link:focus-visible {
  color: var(--accent-light);
  border-color: var(--accent-light);
  background: rgba(74, 154, 106, 0.08);
}

/* Hours and 24/7 badge */
.footer__hours {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.footer__hours-line {
  color: var(--dark-text-muted);
  font-size: 13px;
}

.footer__badge-24 {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(74, 154, 106, 0.12);
  color: var(--accent-light);
  font-size: 13px;
  font-weight: 600;
  padding: 6px 14px;
  border-radius: 6px;
  border: 1px solid rgba(74, 154, 106, 0.2);
  width: fit-content;
  letter-spacing: 0.02em;
}

/* Hours + Bank row below grid */
.footer__hours-bank {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-4) 0 var(--space-4);
  border-bottom: 1px solid var(--accent);
  margin-top: 0;
}

/* Bank accounts */
.footer__bank {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.footer__bank-items {
  display: flex;
  gap: var(--space-4);
}

.footer__bank-label {
  font-size: 12px;
  color: var(--dark-text-muted);
  margin-bottom: 2px;
}

.footer__bank-item {
  display: flex;
  align-items: center;
  gap: 8px;
}

.footer__bank-currency {
  font-size: 11px;
  font-weight: 600;
  color: var(--accent-light);
  background: rgba(74, 154, 106, 0.1);
  padding: 2px 8px;
  border-radius: 4px;
  letter-spacing: 0.04em;
  flex-shrink: 0;
}

.footer__bank-number {
  font-family: 'Space Grotesk', monospace;
  font-size: 12px;
  color: var(--dark-text-secondary);
  letter-spacing: 0.04em;
  white-space: nowrap;
}

.footer__bank-copy {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 6px;
  border: 1px solid var(--dark-border);
  color: var(--dark-text-muted);
  font-size: 12px;
  cursor: pointer;
  transition: all 0.2s ease;
  flex-shrink: 0;
  background: none;
}

.footer__bank-copy:hover,
.footer__bank-copy:focus-visible {
  color: var(--accent-light);
  border-color: var(--accent-light);
}

.footer__bank-copy.is-copied {
  color: var(--accent-light);
  border-color: var(--accent-light);
  background: rgba(74, 154, 106, 0.08);
}

/* Navigation lists */
.footer__list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* Social media links */
.footer__social {
  display: flex;
  gap: var(--space-2);
  margin-top: var(--space-3);
}

.footer__social-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 8px;
  border: 1px solid var(--dark-border);
  color: var(--dark-text-secondary);
  font-size: 16px;
  transition: all 0.2s ease;
}

.footer__social-link:hover,
.footer__social-link:focus-visible {
  color: var(--accent-light);
  border-color: var(--accent-light);
  background: rgba(74, 154, 106, 0.08);
}

/* Bottom bar */
.footer__bottom {
  padding: var(--space-4) 0;
}

.footer__bottom-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.footer__copyright {
  color: var(--dark-text-muted);
  font-size: 13px;
}

/* Media logos section */
.footer__media {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.footer__media-label {
  color: var(--dark-text-muted);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  white-space: nowrap;
}

.footer__media-logos {
  display: flex;
  align-items: baseline;
  gap: var(--space-1);
}

.footer__media-sep {
  color: var(--dark-text-muted);
  opacity: 0.3;
  font-size: 13px;
}

/* Font-based media logos, matching hero/media section style */
.footer__media-text {
  color: var(--dark-text-muted);
  opacity: 0.55;
  transition: opacity 0.2s ease;
  line-height: 1;
}

.footer__media-text:hover {
  opacity: 0.85;
}

.footer__media--fakt {
  font-family: 'Space Grotesk', Impact, sans-serif;
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.footer__media--onet {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 16px;
  font-weight: 700;
}

.footer__media--natemat {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 15px;
  font-weight: 700;
}

.footer__media-light {
  font-weight: 300;
  opacity: 0.65;
}

.footer__media--prawo {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 600;
}

.footer__media-dot {
  font-weight: 500;
  font-size: 0.75em;
  opacity: 0.7;
}

.footer__media--trojka {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

/* Award badge */
.footer__badge-img {
  height: 48px;
  width: auto;
  background: #fff;
  border-radius: 6px;
  padding: 4px;
  opacity: 0.9;
  transition: opacity 0.2s ease;
}

.footer__badge-img:hover {
  opacity: 1;
}

/* ── Tablet: 2 columns ── */
@media (max-width: 1024px) {
  .footer__grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-6) var(--space-5);
  }
}

/* ── Mobile: single column ── */
@media (max-width: 640px) {
  .site-footer {
    padding-top: var(--space-8);
  }

  .footer__grid {
    grid-template-columns: 1fr;
    gap: var(--space-6);
    padding-bottom: var(--space-3);
  }

  .footer__hours-bank {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-3);
  }

  .footer__bank-items {
    flex-direction: column;
    gap: 8px;
  }

  .footer__bottom-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-3);
  }

  .footer__media {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-1);
  }

  .footer__media-logos {
    flex-wrap: wrap;
    gap: 6px;
  }
}

/* Focus styles for accessibility */
.site-footer a:focus-visible,
.site-footer button:focus-visible {
  outline: 2px solid var(--accent-light);
  outline-offset: 2px;
  border-radius: 2px;
}

/* ============================================================
   SPECJALIZACJE — Hero (Manifest)
   ============================================================ */

.sp-hero {
  position: relative;
  background: var(--dark-bg);
  /* padding-top clears fixed header: top-bar 44px + nav ~72px = ~116px + breathing room */
  padding: clamp(140px, 12vw, 180px) 0 var(--space-5);
  overflow: hidden;
}

/* Radial gradient overlays for depth — matching hh-hero pattern */
.sp-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 20% 40%, rgba(46,107,71,0.05) 0%, transparent 70%),
    radial-gradient(ellipse 50% 80% at 85% 20%, rgba(46,107,71,0.03) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 50% 100%, rgba(0,0,0,0.3) 0%, transparent 70%);
  pointer-events: none;
}

/* Accent top line — symmetric, matching hh-hero__topline */
.sp-hero__topline {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--accent-light), var(--accent), var(--accent-light), transparent);
  opacity: 0.5;
}

.sp-hero__inner {
  position: relative; /* above ::before */
  max-width: 800px;
  margin: 0 auto;
  padding: 0 var(--space-3);
  text-align: center;
}

/* Breadcrumb */
.sp-hero__breadcrumb {
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--dark-text-muted);
  margin-bottom: var(--space-3);
  list-style: none;
  display: flex;
  justify-content: center;
  gap: 6px;
}
.sp-hero__breadcrumb a {
  color: var(--dark-text-muted);
  text-decoration: none;
  transition: color 0.2s;
}
.sp-hero__breadcrumb a:hover {
  color: var(--accent-light);
}
.sp-hero__breadcrumb-sep {
  color: var(--dark-text-muted);
  user-select: none;
}

/* Eyebrow badge */
.sp-hero__badge {
  margin-bottom: var(--space-3);
}
.sp-hero__badge span {
  display: inline-block;
  padding: 5px 14px;
  border-radius: 100px;
  background: rgba(46,107,71,0.08);
  border: 1px solid rgba(46,107,71,0.18);
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--accent-light);
}

/* H1 */
.sp-hero__heading {
  font-family: var(--font-body);
  font-size: clamp(2.5rem, 2rem + 3vw, 4rem);
  font-weight: 700;
  color: var(--text-inverse);
  line-height: 1.1;
  text-wrap: balance;
  margin-bottom: var(--space-3);
}
.sp-hero__heading em {
  font-style: normal;
  color: var(--accent-light);
}

/* Negations — inline row with separators */
.sp-hero__negations {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px 0;
  margin-bottom: var(--space-2);
}
.sp-hero__negation {
  font-family: var(--font-display);
  font-size: clamp(1rem, 0.9rem + 0.5vw, 1.2rem);
  font-style: italic;
  font-weight: 400;
  color: var(--dark-text-muted);
  line-height: 1.5;
  opacity: 0;
  animation: spNegationIn 0.5s ease forwards;
}
.sp-hero__negation:nth-child(1) { animation-delay: 0.6s; }
.sp-hero__negation:nth-child(3) { animation-delay: 0.9s; }
.sp-hero__negation:nth-child(5) { animation-delay: 1.2s; }
.sp-hero__negation-sep {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: var(--dark-text-muted);
  margin: 0 12px;
  flex-shrink: 0;
  opacity: 0;
  animation: spNegationIn 0.3s ease forwards;
}
.sp-hero__negation-sep:nth-child(2) { animation-delay: 0.75s; }
.sp-hero__negation-sep:nth-child(4) { animation-delay: 1.05s; }

@keyframes spNegationIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Lead paragraph — the resolving "yes" */
.sp-hero__lead {
  font-family: var(--font-display);
  font-size: clamp(1.1rem, 1rem + 0.5vw, 1.35rem);
  font-style: italic;
  font-weight: 400;
  color: var(--dark-text-secondary);
  line-height: 1.65;
  max-width: 600px;
  margin: 0 auto var(--space-3);
  opacity: 0;
  animation: spNegationIn 0.6s ease 1.5s forwards;
}

/* Divider */
.sp-hero__divider {
  width: 40px;
  height: 1px;
  background: var(--dark-border);
  border: none;
  margin: 0 auto var(--space-3);
}

/* Trust bar */
.sp-hero__trust {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px 16px;
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--dark-text-muted);
  margin-bottom: var(--space-4);
}
.sp-hero__trust-item {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  white-space: nowrap;
}
.sp-hero__trust-item svg {
  width: 14px;
  height: 14px;
  stroke: var(--accent-light);
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex-shrink: 0;
}
.sp-hero__trust-sep {
  color: var(--dark-text-muted);
  user-select: none;
}

/* Animated counter for "440" */
@property --sp-counter {
  syntax: '<integer>';
  initial-value: 0;
  inherits: false;
}
.sp-hero__trust-counter {
  animation: spCountUp 1.8s ease-out 0.8s forwards;
  counter-reset: sp-count var(--sp-counter);
}
.sp-hero__trust-counter::after {
  content: counter(sp-count);
}
@keyframes spCountUp {
  from { --sp-counter: 0; }
  to   { --sp-counter: 440; }
}

/* CTAs */
.sp-hero__ctas {
  display: flex;
  justify-content: center;
  gap: var(--space-2);
  flex-wrap: wrap;
  margin-bottom: var(--space-4);
}
.sp-hero__ctas .btn-accent,
.sp-hero__ctas .btn-ghost-dark {
  text-decoration: none;
}
.sp-hero__ctas .btn-accent svg,
.sp-hero__ctas .btn-ghost-dark svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
}
.sp-hero__ctas .btn-accent:focus-visible,
.sp-hero__ctas .btn-ghost-dark:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
}

/* Scroll-down connector line */
.sp-hero__scroll-line {
  width: 1px;
  height: 40px;
  background: linear-gradient(to bottom, var(--dark-border), transparent);
  border: none;
  margin: 0 auto;
}

/* ── Entrance animations ── */
@keyframes spFadeInUp {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}
.sp-anim {
  opacity: 0;
  animation: spFadeInUp 0.6s ease both;
}
.sp-anim--1 { animation-delay: 0.05s; }
.sp-anim--2 { animation-delay: 0.15s; }
.sp-anim--3 { animation-delay: 0.25s; }
.sp-anim--4 { animation-delay: 0.55s; }
.sp-anim--5 { animation-delay: 1.6s; }
.sp-anim--6 { animation-delay: 1.75s; }
.sp-anim--7 { animation-delay: 1.9s; }

/* ── Specjalizacje Hero — Mobile ── */
@media (max-width: 640px) {
  .sp-hero {
    padding: clamp(120px, 10vw, 150px) 0 var(--space-4);
  }
  .sp-hero__inner {
    text-align: left;
  }
  .sp-hero__breadcrumb {
    justify-content: flex-start;
  }
  .sp-hero__badge {
    text-align: left;
  }
  .sp-hero__negations {
    justify-content: flex-start;
  }
  .sp-hero__lead {
    margin-left: 0;
    margin-right: 0;
  }
  .sp-hero__divider {
    margin-left: 0;
  }
  .sp-hero__trust {
    justify-content: flex-start;
  }
  .sp-hero__ctas {
    flex-direction: column;
  }
  .sp-hero__ctas .btn-accent,
  .sp-hero__ctas .btn-ghost-dark {
    width: 100%;
    justify-content: center;
    text-align: center;
  }
  .sp-hero__scroll-line {
    display: none;
  }
}

/* ── Specjalizacje Hero — Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  .sp-anim,
  .sp-hero__negation,
  .sp-hero__negation-sep,
  .sp-hero__lead,
  .sp-hero__trust-counter {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
  }
  .sp-hero__trust-counter {
    --sp-counter: 440;
  }
}

/* ============================================================
   SPECJALIZACJE — Orbit (Interaktywna mapa)
   ============================================================ */

.orbit-section {
  background: var(--bg-primary);
  padding: clamp(48px, 6vw, 80px) 0;
}

.orbit-section__heading {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 1.2rem + 2vw, 2.5rem);
  font-weight: 700;
  color: var(--text-primary);
  text-align: center;
  margin-bottom: var(--space-2);
}
.orbit-section__desc {
  font-family: var(--font-body);
  font-size: clamp(0.9rem, 0.85rem + 0.25vw, 1rem);
  font-weight: 400;
  color: var(--text-tertiary);
  text-align: center;
  max-width: 540px;
  margin: 0 auto clamp(32px, 4vw, 56px);
  line-height: 1.6;
}

/* ── Diagram container ── */
.orbit {
  position: relative;
  max-width: 940px;
  aspect-ratio: 4 / 3;
  margin: 0 auto;
  contain: layout style;
  opacity: 0; /* shown by JS via .orbit--ready */
}
.orbit--ready {
  opacity: 1;
}

/* ── SVG lines ── */
.orbit__svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1;
}
.orbit__svg path {
  fill: none;
  stroke: var(--bg-tertiary);
  stroke-width: 1;
  stroke-dasharray: 5 5;
  transition: stroke 0.4s ease, stroke-dasharray 0.3s ease;
}
.orbit__svg path.is-active {
  stroke: var(--accent);
  stroke-dasharray: none;
}
.orbit__svg path.is-emergency {
  stroke: rgba(74,154,106,0.25);
  stroke-dasharray: none;
}
.orbit__svg path.is-emergency.is-active {
  stroke: var(--emergency-accent);
}
.orbit__svg path.flash {
  animation: orbitLineFlash 0.3s ease forwards;
}
@keyframes orbitLineFlash {
  0%   { stroke-opacity: 0.25; }
  50%  { stroke-opacity: 0.8; }
  100% { stroke-opacity: 0.25; }
}

/* ── Radial glow behind center ── */
.orbit__glow {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 200px;
  height: 200px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(46,107,71,0.08) 0%, transparent 70%);
  transform: translate(-50%, -50%) scale(0);
  opacity: 0;
  pointer-events: none;
  z-index: 2;
}

/* ── Central node ── */
.orbit__center {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 140px;
  height: 140px;
  border-radius: 50%;
  background: radial-gradient(circle at 40% 35%, var(--accent-light) 0%, var(--accent) 70%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  z-index: 10;
  box-shadow: 0 4px 24px rgba(46,107,71,0.2);
  transition: box-shadow 0.3s ease;
}
.orbit__center:hover {
  box-shadow: 0 0 60px rgba(46,107,71,0.3);
}
.orbit__center-label {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: #fff;
  text-align: center;
  line-height: 1.2;
}
.orbit__center-sub {
  font-family: var(--font-display);
  font-size: 11px;
  font-weight: 400;
  font-style: italic;
  color: rgba(255,255,255,0.7);
  text-align: center;
  line-height: 1.2;
}
.orbit__center-stat {
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 600;
  color: rgba(255,255,255,0.5);
  text-align: center;
  margin-top: 2px;
  padding: 2px 8px;
  border-radius: 100px;
  background: rgba(255,255,255,0.1);
  line-height: 1.3;
}

/* Orbital rings */
.orbit__center::before,
.orbit__center::after {
  content: '';
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}
.orbit__center::before {
  inset: -35px;
  border: 1px solid rgba(46,107,71,0.1);
  animation: ringRotate 60s linear infinite;
}
.orbit__center::after {
  inset: -75px;
  border: 1px dashed rgba(46,107,71,0.06);
  animation: ringRotateReverse 90s linear infinite;
}
@keyframes ringRotate { to { transform: rotate(360deg); } }
@keyframes ringRotateReverse { to { transform: rotate(-360deg); } }

/* ── Satellite nodes ── */
.orbit__node {
  position: relative;
  z-index: 20;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 20px;
  background: var(--bg-elevated);
  border: 1px solid var(--bg-tertiary);
  border-radius: 12px;
  box-shadow: var(--shadow-sm);
  text-decoration: none;
  color: var(--text-primary);
  cursor: pointer;
  transform-style: preserve-3d;
  overflow: visible;
  /* Fix: explicit properties instead of 'all' — avoids animating left/top on resize */
  transition:
    border-color 0.35s cubic-bezier(0.16, 1, 0.3, 1),
    box-shadow 0.35s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Accent top line on card */
.orbit__node::before {
  content: '';
  position: absolute;
  top: -1px;
  left: 12px;
  right: 12px;
  height: 2px;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--accent-light), var(--accent));
  opacity: 0;
  transition: opacity 0.35s ease;
}
.orbit__node:hover::before {
  opacity: 1;
}

.orbit__node:hover {
  border-color: var(--accent-border-solid);
  box-shadow: var(--shadow-md);
}
.orbit__node:hover .orbit__node-name {
  color: var(--accent);
}
.orbit__node:hover .orbit__node-arrow {
  opacity: 1;
  transform: translateX(0);
}
.orbit__node:hover .orbit__node-icon {
  transform: scale(1.08) rotate(8deg);
  background: var(--accent);
  border-color: var(--accent);
}
.orbit__node:hover .orbit__node-icon svg {
  stroke: #fff;
}
.orbit__node:focus-visible {
  outline: 2px solid var(--accent-light);
  outline-offset: 3px;
  box-shadow: var(--shadow-focus);
}

/* Status indicator dot */
.orbit__node-status {
  position: absolute;
  top: -3px;
  right: -3px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent-light);
  border: 2px solid var(--bg-elevated);
  z-index: 2;
}

/* Connector dot (anchors SVG line to card edge) */
.orbit__node-connector {
  position: absolute;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--bg-tertiary);
  z-index: 2;
  transition: background 0.3s ease;
  /* JS positions this on the edge facing the center */
}
.orbit__node:hover .orbit__node-connector {
  background: var(--accent);
}

/* Node icon */
.orbit__node-icon {
  width: 40px;
  height: 40px;
  border-radius: 8px;
  background: var(--accent-bg-solid);
  border: 1px solid var(--accent-border-solid);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition:
    transform 0.35s cubic-bezier(0.16, 1, 0.3, 1),
    background 0.35s ease,
    border-color 0.35s ease;
}
.orbit__node-icon svg {
  width: 20px;
  height: 20px;
  stroke: var(--accent);
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: stroke 0.35s ease;
}

/* Node text */
.orbit__node-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.orbit__node-name {
  display: flex;
  align-items: center;
  gap: 4px;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  transition: color 0.2s;
  white-space: nowrap;
}
/* Hover arrow after name */
.orbit__node-arrow {
  display: inline-block;
  font-size: 12px;
  opacity: 0;
  transform: translateX(-4px);
  transition: opacity 0.25s ease, transform 0.25s ease;
  color: var(--accent);
}
.orbit__node-desc {
  display: block;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 400;
  color: var(--text-tertiary);
  line-height: 1.4;
  max-width: 180px;
}
.orbit__node-meta {
  display: block;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 500;
  color: var(--text-muted);
}
/* Accent color on the number in meta */
.orbit__node-meta strong {
  color: var(--accent);
  font-weight: 700;
}

/* Preview tags (appear on hover with delay) */
.orbit__node-preview {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height 0.35s cubic-bezier(0.16, 1, 0.3, 1) 0.2s, opacity 0.3s ease 0.2s;
  margin-top: 0;
}
.orbit__node:hover .orbit__node-preview {
  max-height: 30px;
  opacity: 1;
  margin-top: 4px;
}
.orbit__node-preview-tag {
  display: inline-block;
  padding: 2px 7px;
  border-radius: 100px;
  font-family: var(--font-body);
  font-size: 9px;
  font-weight: 600;
  background: var(--accent-bg-solid);
  color: var(--accent);
  border: 1px solid var(--accent-border-solid);
  white-space: nowrap;
}

/* Inner glow following cursor */
.orbit__node-glow {
  position: absolute;
  inset: 0;
  border-radius: 12px;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.4s;
}

/* ── Emergency node (Adwokat 24) ── */
.orbit__node--emergency {
  background: var(--emergency-bg);
  border-color: rgba(74,154,106,0.25);
}
/* Emergency accent top line override */
.orbit__node--emergency::before {
  background: linear-gradient(90deg, var(--emergency-accent), rgba(74,154,106,0.3));
}
.orbit__node--emergency .orbit__node-icon {
  background: rgba(74,154,106,0.1);
  border-color: rgba(74,154,106,0.2);
}
.orbit__node--emergency .orbit__node-icon .pulse-dot {
  width: 10px;
  height: 10px;
}
.orbit__node--emergency .orbit__node-name {
  color: var(--emergency-text);
}
.orbit__node--emergency .orbit__node-arrow {
  color: var(--emergency-accent);
}
.orbit__node--emergency .orbit__node-desc {
  color: rgba(200,200,200,0.45);
}
.orbit__node--emergency .orbit__node-meta {
  color: rgba(200,200,200,0.5);
}
.orbit__node--emergency .orbit__node-meta strong {
  color: var(--emergency-accent);
}
.orbit__node--emergency .orbit__node-status {
  background: var(--emergency-accent);
  border-color: var(--emergency-bg);
  animation: statusPulse 2s ease-in-out infinite;
}
@keyframes statusPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(74,154,106,0.4); }
  50%      { box-shadow: 0 0 0 4px rgba(74,154,106,0); }
}
.orbit__node--emergency .orbit__node-preview-tag {
  background: rgba(74,154,106,0.1);
  color: var(--emergency-accent);
  border-color: rgba(74,154,106,0.2);
}
.orbit__node--emergency .orbit__node-connector {
  background: rgba(74,154,106,0.4);
}
.orbit__node--emergency:hover .orbit__node-connector {
  background: var(--emergency-accent);
}
.orbit__node--emergency:hover {
  border-color: var(--emergency-accent);
  box-shadow: 0 0 24px rgba(74,154,106,0.12), var(--shadow-md);
}
.orbit__node--emergency:hover .orbit__node-name {
  color: var(--emergency-accent);
}
.orbit__node--emergency:hover .orbit__node-icon {
  background: var(--emergency-accent);
  border-color: var(--emergency-accent);
  transform: scale(1.08) rotate(0deg);
}

/* Emergency ambient glow — fix z-index stacking */
.orbit__node--emergency-glow {
  position: absolute;
  inset: -40px;
  border-radius: 60px;
  background: radial-gradient(ellipse, rgba(74,154,106,0.1) 0%, transparent 70%);
  animation: ambientShift 8s ease-in-out infinite alternate;
  pointer-events: none;
  z-index: -1;
}
@keyframes ambientShift {
  0%   { opacity: 0.5; transform: scale(0.95); }
  100% { opacity: 1; transform: scale(1.05); }
}

/* Conic gradient animated border (emergency) */
@property --orbit-conic-angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}
.orbit__node--emergency-border {
  position: absolute;
  inset: -1px;
  border-radius: 13px;
  background: conic-gradient(
    from var(--orbit-conic-angle),
    transparent 0%,
    var(--emergency-accent) 10%,
    transparent 20%,
    transparent 100%
  );
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  padding: 1px;
  animation: orbitConicSpin 8s linear infinite;
  pointer-events: none;
  z-index: 1;
}
@keyframes orbitConicSpin {
  to { --orbit-conic-angle: 360deg; }
}
/* Fallback: no @property support (Firefox <128) */
.orbit__node--emergency.no-houdini .orbit__node--emergency-border {
  display: none;
}

/* Active state (tablet) */
.orbit__node.is-active {
  border-color: var(--accent-border-solid);
  box-shadow: var(--shadow-md);
}
.orbit__node.is-active::before {
  opacity: 1;
}
.orbit__node.is-active .orbit__node-icon {
  transform: scale(1.08) rotate(8deg);
  background: var(--accent);
  border-color: var(--accent);
}
.orbit__node.is-active .orbit__node-icon svg {
  stroke: #fff;
}
.orbit__node--emergency.is-active {
  border-color: var(--emergency-accent);
}
.orbit__node--emergency.is-active .orbit__node-icon {
  background: var(--emergency-accent);
  border-color: var(--emergency-accent);
  transform: scale(1.08) rotate(0deg);
}

/* ── Float animations (applied via wrapper to avoid transform conflict with hover/tilt) ── */
@keyframes orbitFloat1 { 0%, 100% { transform: translate(0, 0); } 50% { transform: translate(2px, -4px); } }
@keyframes orbitFloat2 { 0%, 100% { transform: translate(0, 0); } 50% { transform: translate(-3px, 3px); } }
@keyframes orbitFloat3 { 0%, 100% { transform: translate(0, 0); } 50% { transform: translate(3px, -2px); } }
@keyframes orbitFloat4 { 0%, 100% { transform: translate(0, 0); } 50% { transform: translate(-2px, -3px); } }
@keyframes orbitFloat5 { 0%, 100% { transform: translate(0, 0); } 50% { transform: translate(4px, 2px); } }

.orbit__float-wrap { position: absolute; z-index: 20; }
.orbit__float-wrap[data-float="1"] { animation: orbitFloat1 7s ease-in-out infinite; }
.orbit__float-wrap[data-float="2"] { animation: orbitFloat2 8s ease-in-out infinite; }
.orbit__float-wrap[data-float="3"] { animation: orbitFloat3 9s ease-in-out infinite; }
.orbit__float-wrap[data-float="4"] { animation: orbitFloat4 6.5s ease-in-out infinite; }
.orbit__float-wrap[data-float="5"] { animation: orbitFloat5 8.5s ease-in-out infinite; }

/* ── Tooltip ── */
.orbit__tooltip {
  position: absolute;
  z-index: 30;
  width: 300px;
  background: var(--bg-elevated);
  border: 1px solid var(--bg-tertiary);
  border-radius: 14px;
  padding: 24px;
  pointer-events: auto;
  transition: opacity 0.2s ease;
}

/* Tooltip arrow */
.orbit__tooltip::before {
  content: '';
  position: absolute;
  width: 12px;
  height: 12px;
  background: var(--bg-elevated);
  border-right: 1px solid var(--bg-tertiary);
  border-bottom: 1px solid var(--bg-tertiary);
  top: 28px;
}
.orbit__tooltip[data-side="left"]::before {
  right: -7px;
  transform: rotate(-45deg);
}
.orbit__tooltip[data-side="right"]::before {
  left: -7px;
  transform: rotate(135deg);
}

/* Directional shadow */
.orbit__tooltip[data-side="left"] {
  box-shadow: -8px 6px 32px rgba(13,13,13,0.08), -2px 2px 8px rgba(13,13,13,0.04);
}
.orbit__tooltip[data-side="right"] {
  box-shadow: 8px 6px 32px rgba(13,13,13,0.08), 2px 2px 8px rgba(13,13,13,0.04);
}

/* Tooltip content */
.orbit__tooltip-title {
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 8px;
}
.orbit__tooltip-desc {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text-tertiary);
  line-height: 1.6;
  margin-bottom: 14px;
}
.orbit__tooltip-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-bottom: 16px;
}
.orbit__tooltip-tags a {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 100px;
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 600;
  background: var(--accent-bg-solid);
  color: var(--accent);
  border: 1px solid var(--accent-border-solid);
  text-decoration: none;
  transition: all 0.2s;
}
.orbit__tooltip-tags a:hover {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
.orbit__tooltip-cta {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  display: inline-block;
  transition: color 0.2s;
}
.orbit__tooltip-cta:hover {
  color: var(--accent-hover);
}

/* Tooltip entrance stagger */
.orbit__tooltip.is-entering .orbit__tooltip-title,
.orbit__tooltip.is-entering .orbit__tooltip-desc,
.orbit__tooltip.is-entering .orbit__tooltip-tags,
.orbit__tooltip.is-entering .orbit__tooltip-cta {
  opacity: 0;
  transform: translateY(6px);
}
.orbit__tooltip.is-entering .orbit__tooltip-title { animation: tooltipItemIn 0.25s ease forwards 0s; }
.orbit__tooltip.is-entering .orbit__tooltip-desc  { animation: tooltipItemIn 0.25s ease forwards 0.05s; }
.orbit__tooltip.is-entering .orbit__tooltip-tags   { animation: tooltipItemIn 0.25s ease forwards 0.1s; }
.orbit__tooltip.is-entering .orbit__tooltip-cta    { animation: tooltipItemIn 0.25s ease forwards 0.15s; }
@keyframes tooltipItemIn {
  to { opacity: 1; transform: translateY(0); }
}

/* Emergency tooltip variant */
.orbit__tooltip--emergency {
  background: var(--emergency-bg);
  border-color: rgba(74,154,106,0.25);
}
.orbit__tooltip--emergency::before {
  background: var(--emergency-bg);
  border-color: rgba(74,154,106,0.25);
}
.orbit__tooltip--emergency .orbit__tooltip-title {
  color: var(--emergency-text);
}
.orbit__tooltip--emergency .orbit__tooltip-desc {
  color: rgba(200,200,200,0.7);
}
.orbit__tooltip--emergency .orbit__tooltip-tags a {
  background: rgba(74,154,106,0.1);
  color: var(--emergency-accent);
  border-color: rgba(74,154,106,0.2);
}
.orbit__tooltip--emergency .orbit__tooltip-tags a:hover {
  background: var(--emergency-accent);
  color: #fff;
}
.orbit__tooltip--emergency .orbit__tooltip-cta {
  color: var(--emergency-accent);
}

/* ── Tablet detail panel ── */
.orbit__panel {
  max-width: 100%;
  margin-top: var(--space-3);
  padding: 24px;
  background: var(--bg-elevated);
  border: 1px solid var(--bg-tertiary);
  border-radius: 14px;
  box-shadow: var(--shadow-sm);
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height 0.4s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.3s ease;
}
.orbit__panel.is-open {
  max-height: 400px;
  opacity: 1;
}
.orbit__panel-title {
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 8px;
}
.orbit__panel-desc {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text-tertiary);
  line-height: 1.6;
  margin-bottom: 16px;
}
.orbit__panel-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 16px;
}
.orbit__panel-tags a {
  display: inline-block;
  padding: 5px 12px;
  border-radius: 100px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  background: var(--accent-bg-solid);
  color: var(--accent);
  border: 1px solid var(--accent-border-solid);
  text-decoration: none;
  transition: all 0.2s;
}
.orbit__panel-tags a:hover {
  background: var(--accent);
  color: #fff;
}
.orbit__panel-cta {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
}

/* ── Mobile fallback: accordion cards ── */
.orbit-mobile {
  display: none;
  flex-direction: column;
  gap: 12px;
  max-width: 640px;
  margin: 0 auto;
}

.orbit-mobile__card {
  background: var(--bg-elevated);
  border: 1px solid var(--bg-tertiary);
  border-radius: 12px;
  overflow: hidden;
}

.orbit-mobile__header {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 16px 20px;
  background: none;
  border: none;
  cursor: pointer;
  font-family: var(--font-body);
  text-align: left;
  color: var(--text-primary);
  transition: background 0.2s;
}
.orbit-mobile__header:hover {
  background: var(--bg-secondary);
}
.orbit-mobile__header:focus-visible {
  outline: none;
  box-shadow: inset var(--shadow-focus);
}
.orbit-mobile__header[aria-expanded="true"] .orbit-mobile__chevron {
  transform: rotate(180deg);
}

.orbit-mobile__icon {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  background: var(--accent-bg-solid);
  border: 1px solid var(--accent-border-solid);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.orbit-mobile__icon svg {
  width: 18px;
  height: 18px;
  stroke: var(--accent);
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.orbit-mobile__label {
  flex: 1;
  min-width: 0;
}
.orbit-mobile__name {
  display: block;
  font-size: 14px;
  font-weight: 600;
}
.orbit-mobile__meta {
  display: block;
  font-size: 11px;
  font-weight: 500;
  color: var(--text-muted);
}

.orbit-mobile__chevron {
  width: 20px;
  height: 20px;
  stroke: var(--text-muted);
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex-shrink: 0;
  transition: transform 0.3s ease;
}

.orbit-mobile__body {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.orbit-mobile__body > * {
  padding: 0 20px;
}
.orbit-mobile__desc {
  font-size: 13px;
  color: var(--text-tertiary);
  line-height: 1.6;
  margin-bottom: 14px;
  padding-top: 4px;
}
.orbit-mobile__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}
.orbit-mobile__tag {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  min-height: 36px;
  border-radius: 100px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  background: var(--accent-bg-solid);
  color: var(--accent);
  border: 1px solid var(--accent-border-solid);
  text-decoration: none;
  transition: all 0.2s;
}
.orbit-mobile__tag:hover {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
.orbit-mobile__cta {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  padding-bottom: 20px;
}

/* Emergency card */
.orbit-mobile__card--emergency {
  background: var(--emergency-bg);
  border-color: rgba(74,154,106,0.25);
}
.orbit-mobile__card--emergency .orbit-mobile__header:hover {
  background: rgba(255,255,255,0.03);
}
.orbit-mobile__card--emergency .orbit-mobile__icon {
  background: rgba(74,154,106,0.1);
  border-color: rgba(74,154,106,0.2);
}
.orbit-mobile__card--emergency .orbit-mobile__name {
  color: var(--emergency-text);
}
.orbit-mobile__card--emergency .orbit-mobile__meta {
  color: rgba(200,200,200,0.5);
}
.orbit-mobile__card--emergency .orbit-mobile__chevron {
  stroke: var(--emergency-text);
}
.orbit-mobile__card--emergency .orbit-mobile__desc {
  color: rgba(200,200,200,0.7);
}
.orbit-mobile__card--emergency .orbit-mobile__tag {
  background: rgba(74,154,106,0.1);
  color: var(--emergency-accent);
  border-color: rgba(74,154,106,0.2);
}
.orbit-mobile__card--emergency .orbit-mobile__tag:hover {
  background: var(--emergency-accent);
  color: #fff;
}
.orbit-mobile__card--emergency .orbit-mobile__cta {
  color: var(--emergency-accent);
}

/* ── Orbit entrance (line draw) ── */
.orbit__svg path.is-drawing {
  transition: none;
}

/* ── Orbit responsive ── */

/* Tablet: 860–1100px */
@media (max-width: 1100px) and (min-width: 860px) {
  .orbit__tooltip {
    display: none !important;
  }
  .orbit__panel {
    position: relative;
  }
}

/* Mobile: < 860px */
@media (max-width: 859px) {
  .orbit {
    display: none !important;
  }
  .orbit-mobile {
    display: flex;
  }
}

/* ── Orbit reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  .orbit__center::before,
  .orbit__center::after {
    animation: none !important;
  }
  .orbit__float-wrap {
    animation: none !important;
  }
  .orbit__node--emergency-glow {
    animation: none !important;
  }
  .orbit__node--emergency-border {
    animation: none !important;
  }
  .orbit__node--emergency .orbit__node-status {
    animation: none !important;
  }
  .orbit__glow {
    opacity: 0.5 !important;
    transform: translate(-50%, -50%) scale(1.5) !important;
  }
}

/* ── Hub skip link (diagram → list) ── */
.hh-skip-link {
  position: absolute;
  left: 50%;
  transform: translateX(-50%) translateY(-120%);
  z-index: 100;
  padding: 10px 24px;
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--accent);
  background: var(--bg-elevated);
  border: 1px solid var(--accent-border-solid);
  border-radius: 6px;
  box-shadow: var(--shadow-md);
  text-decoration: none;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: transform 0.25s ease, opacity 0.25s ease;
}
.hh-skip-link:focus {
  transform: translateX(-50%) translateY(12px);
  opacity: 1;
  pointer-events: auto;
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

/* ============================================================
   SPECJALIZACJE — Lista specjalizacji (dostępna alternatywa)
   ============================================================ */

.spec-list {
  background: var(--bg-secondary);
  padding: clamp(48px, 6vw, 80px) 0;
}
.spec-list__inner {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 var(--space-4, 24px);
}
.spec-list__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--space-3, 16px);
}
.spec-list__eyebrow svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  stroke-width: 2;
  fill: none;
}
.spec-list__heading {
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 1rem + 2vw, 2.2rem);
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: var(--space-3, 16px);
  line-height: 1.2;
}
.spec-list__intro {
  font-family: var(--font-body);
  font-size: clamp(0.9rem, 0.85rem + 0.25vw, 1rem);
  color: var(--text-tertiary);
  line-height: 1.7;
  max-width: 680px;
  margin-bottom: clamp(28px, 4vw, 48px);
}
.spec-list__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
@media (max-width: 600px) {
  .spec-list__grid {
    grid-template-columns: 1fr;
  }
}
.spec-list__card {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 20px 24px;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 10px;
  text-decoration: none;
  color: inherit;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.spec-list__card:hover {
  border-color: var(--accent-border-solid);
  box-shadow: var(--shadow-sm);
}
.spec-list__card:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.spec-list__card-icon {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--accent-bg);
  border-radius: 8px;
  color: var(--accent);
}
.spec-list__card-icon svg {
  width: 20px;
  height: 20px;
  stroke: currentColor;
  stroke-width: 2;
  fill: none;
}
.spec-list__card--emergency .spec-list__card-icon {
  background: var(--emergency-bg);
  color: var(--emergency-accent);
}
.spec-list__card-body {
  flex: 1;
  min-width: 0;
}
.spec-list__card-name {
  display: block;
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 4px;
}
.spec-list__card-desc {
  display: block;
  font-family: var(--font-body);
  font-size: 0.82rem;
  color: var(--text-tertiary);
  line-height: 1.5;
}
.spec-list__card-arrow {
  flex-shrink: 0;
  align-self: center;
  color: var(--text-muted);
  font-size: 1.1rem;
  transition: transform 0.2s ease, color 0.2s ease;
}
.spec-list__card:hover .spec-list__card-arrow {
  transform: translateX(3px);
  color: var(--accent);
}
.spec-list__cta-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  margin-top: clamp(32px, 4vw, 48px);
}
.spec-list__cta-sub {
  font-family: var(--font-body);
  font-size: 0.8rem;
  color: var(--text-muted);
}

/* ============================================================
   CATEGORY HERO — Split portrait bleed (sprawy-karne etc.)
   ============================================================ */

.cat-hero {
  position: relative;
  background: var(--dark-bg);
  min-height: auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(80px, 10vw, 140px) 0 clamp(48px, 5vw, 72px);
  overflow: hidden;
}

/* Subtle bottom vignette */
.cat-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 50% at 50% 100%, rgba(0,0,0,0.3) 0%, transparent 70%);
  pointer-events: none;
}

/* Noise grain texture for depth */
.cat-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
  background-repeat: repeat;
  background-size: 180px 180px;
  opacity: 0.4;
  pointer-events: none;
  z-index: 0;
}

/* Accent topline */
.cat-hero__topline {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--accent-light), var(--accent), var(--accent-light), transparent);
  opacity: 0.5;
}

/* Grid: 55/45 split */
.cat-hero__grid {
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: clamp(32px, 4vw, 72px);
  align-items: center;
}

/* ── Text column ── */
.cat-hero__content {
  display: flex;
  flex-direction: column;
  gap: 0;
  position: relative;
  z-index: 2;
}

/* Breadcrumb */
.cat-hero__breadcrumb {
  margin-bottom: var(--space-3);
}
.cat-hero__breadcrumb ol {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0;
  list-style: none;
  padding: 0;
  margin: 0;
}
.cat-hero__breadcrumb li {
  display: flex;
  align-items: center;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  color: var(--dark-text-muted);
  letter-spacing: 0.3px;
}
.cat-hero__breadcrumb li + li::before {
  content: '/';
  margin: 0 8px;
  color: var(--dark-border);
  font-weight: 400;
}
.cat-hero__breadcrumb a {
  color: var(--dark-text-muted);
  text-decoration: none;
  transition: color 0.2s ease;
}
.cat-hero__breadcrumb a:hover {
  color: var(--accent-light);
}
.cat-hero__breadcrumb li[aria-current="page"] {
  color: var(--dark-text-secondary);
}

/* Eyebrow */
.cat-hero__eyebrow {
  margin-bottom: var(--space-2);
}
.cat-hero__eyebrow span {
  display: inline-block;
  padding: 5px 14px;
  border-radius: 100px;
  background: rgba(46,107,71,0.08);
  border: 1px solid rgba(46,107,71,0.18);
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--accent-light);
}

/* H1 — with editorial accent bar */
.cat-hero__heading {
  font-family: var(--font-display);
  font-size: clamp(2.1rem, 1.5rem + 3vw, 3.4rem);
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: -0.025em;
  color: var(--text-inverse);
  margin-bottom: var(--space-3);
}
.cat-hero__heading em {
  font-family: var(--font-display);
  font-style: normal;
  font-weight: 500;
  color: var(--accent-light);
}

/* Lead */
.cat-hero__lead {
  font-family: var(--font-body);
  font-size: clamp(1rem, 0.9rem + 0.5vw, 1.2rem);
  font-weight: 400;
  line-height: 1.65;
  color: var(--dark-text-secondary);
  max-width: 620px;
  margin-bottom: var(--space-4);
}

/* CTAs */
.cat-hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-5);
}
.cat-hero__ctas .btn-accent svg,
.cat-hero__ctas .btn-ghost-dark svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
}
.cat-hero__ctas .btn-accent:focus-visible,
.cat-hero__ctas .btn-ghost-dark:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
}

/* Trust bar */
.cat-hero__trust {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2) 0;
}
.cat-hero__trust-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--dark-text-muted);
}
.cat-hero__trust-item + .cat-hero__trust-item::before {
  content: '';
  display: inline-block;
  width: 1px;
  height: 14px;
  background: var(--dark-border);
  margin: 0 var(--space-2);
  flex-shrink: 0;
}
.cat-hero__trust-item svg {
  width: 14px;
  height: 14px;
  stroke: var(--accent-light);
  fill: none;
  flex-shrink: 0;
}

/* Testimonial spacing in category hero */
.cat-hero .hh-hero__testimonials {
  margin-bottom: var(--space-4);
}

/* ── Photo column ── */
.cat-hero__photo-wrap {
  position: relative;
  align-self: stretch;
  overflow: visible; /* bleed out of grid */
  z-index: 1;
}

.cat-hero__photo {
  position: relative;
  height: 100%;
  min-height: 480px;
  overflow: hidden;
  border-radius: 14px;
}
.cat-hero__photo img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 15%;
  transition: transform 2.5s cubic-bezier(0.16, 1, 0.3, 1);
}
.cat-hero__photo:hover img {
  transform: scale(1.03);
}

/* Badge: Orły Prawa — with shimmer */
@keyframes catHeroShimmer {
  0% { left: -100%; }
  100% { left: 200%; }
}
.cat-hero__award {
  position: absolute;
  top: 16px;
  right: 16px;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px 6px 10px;
  border-radius: 100px;
  background: rgba(46,107,71,0.15);
  border: 1px solid rgba(46,107,71,0.25);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  color: var(--accent-light);
  letter-spacing: 0.3px;
  white-space: nowrap;
  overflow: hidden;
}
.cat-hero__award::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 60%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.08), transparent);
  animation: catHeroShimmer 4s ease-in-out 1.5s infinite;
}
.cat-hero__award > svg {
  width: 16px;
  height: 16px;
  stroke: var(--accent-light);
  fill: none;
  flex-shrink: 0;
}
.cat-hero__award img {
  width: 18px;
  height: 18px;
  object-fit: contain;
}

/* ── Entrance animations ── */
.cat-hero__content .cat-anim {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity 0.55s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.55s cubic-bezier(0.16, 1, 0.3, 1);
}
.cat-hero__content .cat-anim.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.cat-hero__photo-wrap .cat-anim {
  opacity: 0;
  transform: translateX(40px);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}
.cat-hero__photo-wrap .cat-anim.is-visible {
  opacity: 1;
  transform: translateX(0);
}

.cat-hero__award {
  opacity: 0;
  transform: translateY(-8px) scale(0.95);
  transition: opacity 0.45s ease 0.6s,
              transform 0.45s cubic-bezier(0.16, 1, 0.3, 1) 0.6s;
}
.cat-hero__award.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}

/* Animation delay helpers */
.cat-anim-d1 { transition-delay: 0.05s !important; }
.cat-anim-d2 { transition-delay: 0.12s !important; }
.cat-anim-d3 { transition-delay: 0.2s !important; }
.cat-anim-d4 { transition-delay: 0.3s !important; }
.cat-anim-d5 { transition-delay: 0.4s !important; }
.cat-anim-d6 { transition-delay: 0.5s !important; }
.cat-anim-d7 { transition-delay: 0.6s !important; }
.cat-anim-d-photo { transition-delay: 0.18s !important; }

/* ── Responsive: Tablet (601–960) ── */
@media (max-width: 960px) {
  .cat-hero {
    min-height: auto;
    padding: clamp(96px, 12vw, 180px) 0 clamp(32px, 4vw, 48px);
  }
  .cat-hero__grid {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }
  .cat-hero__content {
    order: 1;
  }
  .cat-hero__photo-wrap {
    order: 2;
  }
  .cat-hero__photo {
    min-height: auto;
    max-height: 55vh;
  }
  .cat-hero__photo img {
    max-height: 55vh;
  }
  .cat-hero__award {
    right: 16px;
  }
}

/* ── Responsive: Mobile (≤600) ── */
@media (max-width: 600px) {
  .cat-hero {
    padding: 80px 0 32px;
  }
  .cat-hero__heading {
    margin-bottom: var(--space-2);
  }
  .cat-hero__lead {
    margin-bottom: var(--space-3);
  }
  .cat-hero__ctas {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-1);
    margin-bottom: var(--space-4);
  }
  .cat-hero__ctas .btn-accent,
  .cat-hero__ctas .btn-ghost-dark {
    justify-content: center;
    text-align: center;
    padding: 12px 24px;
  }
  .cat-hero .hh-hero__testimonials {
    margin-bottom: var(--space-3);
  }
  .cat-hero__trust {
    gap: var(--space-1) var(--space-2);
  }
  .cat-hero__trust-item {
    font-size: 12px;
  }
  .cat-hero__trust-item + .cat-hero__trust-item::before {
    display: none;
  }
  .cat-hero__photo {
    max-height: 60vh;
  }
  .cat-hero__photo img {
    max-height: 60vh;
  }
  .cat-hero__breadcrumb {
    margin-bottom: var(--space-2);
  }
  .cat-hero__breadcrumb li {
    font-size: 11px;
  }

  .cat-hero__award {
    right: 16px;
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .cat-hero__content .cat-anim,
  .cat-hero__photo-wrap .cat-anim,
  .cat-hero__award {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

/* ============================================================
   STABS — Vertical Tabs + Panel (Specjalizacje pillar)
   ============================================================ */

.stabs {
  background: var(--bg-primary);
  padding: clamp(60px, 8vw, 120px) 0;
}

.stabs__container {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 clamp(20px, 12px + 3vw, 96px);
}

/* ── Section header ── */
.stabs__header {
  text-align: left;
  margin-bottom: clamp(36px, 4vw, 56px);
}

.stabs__header--center {
  text-align: center;
}

.stabs__heading--center {
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}

.stabs__eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2.5px;
  color: var(--accent);
  margin-bottom: 12px;
}

.stabs__heading {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 1.2rem + 1.5vw, 2.4rem);
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.2;
  max-width: 680px;
}

/* ── Two-column grid ── */
.stabs__grid {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: clamp(24px, 3vw, 40px);
  align-items: start;
}

/* ── Left sidebar (card wrapping the tabs) ── */
.stabs__sidebar {
  position: relative;
  background: var(--bg-elevated);
  border: 1px solid var(--bg-tertiary);
  border-radius: 14px;
  overflow: hidden;
}

/* ── Scrollable tab list ── */
.stabs__list {
  overflow-y: auto;
  padding: 6px;
  position: relative;
  scrollbar-width: thin;
  scrollbar-color: var(--accent-border-solid) transparent;
}

.stabs__list::-webkit-scrollbar {
  width: 4px;
}

.stabs__list::-webkit-scrollbar-track {
  background: transparent;
}

.stabs__list::-webkit-scrollbar-thumb {
  background: var(--accent-border-solid);
  border-radius: 4px;
}

.stabs__list::-webkit-scrollbar-thumb:hover {
  background: var(--accent);
}

/* ── Scroll fade hints ── */
.stabs__fade {
  position: absolute;
  left: 0;
  right: 4px;
  height: 32px;
  z-index: 3;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.stabs__fade--top {
  top: 0;
  background: linear-gradient(to bottom, var(--bg-elevated) 0%, transparent 100%);
  border-radius: 14px 14px 0 0;
}

.stabs__fade--bottom {
  bottom: 0;
  background: linear-gradient(to top, var(--bg-elevated) 0%, transparent 100%);
  border-radius: 0 0 14px 14px;
}

.stabs__fade.is-visible {
  opacity: 1;
}

/* ── Sliding indicator bar ── */
.stabs__indicator {
  position: absolute;
  left: 0;
  width: 3px;
  background: var(--accent);
  border-radius: 0 2px 2px 0;
  z-index: 2;
  pointer-events: none;
  transition: top 0.35s cubic-bezier(0.16, 1, 0.3, 1),
              height 0.35s cubic-bezier(0.16, 1, 0.3, 1);
}

/* ── Individual tab ── */
.stab {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 10px;
  border: none;
  background: transparent;
  cursor: pointer;
  width: 100%;
  text-align: left;
  font-family: var(--font-body);
  position: relative;
  z-index: 1;
  transition: background 0.25s ease;
}

.stab:hover {
  background: var(--bg-secondary);
}

.stab.is-active {
  background: rgba(46, 107, 71, 0.04);
}

.stab:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}

/* ── Tab icon ── */
.stab__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  min-width: 40px;
  border-radius: 10px;
  background: var(--accent-bg-solid);
  border: 1px solid var(--accent-border-solid);
  transition: all 0.35s cubic-bezier(0.16, 1, 0.3, 1);
}

.stab__icon svg {
  width: 20px;
  height: 20px;
  stroke: var(--accent);
  fill: none;
  stroke-width: 1.8;
  transition: stroke 0.3s ease;
}

.stab.is-active .stab__icon {
  background: var(--accent);
  border-color: var(--accent);
  box-shadow: 0 3px 10px rgba(46, 107, 71, 0.2);
}

.stab.is-active .stab__icon svg {
  stroke: #fff;
}

/* ── Tab text (two lines) ── */
.stab__text {
  display: flex;
  flex-direction: column;
  gap: 1px;
  flex: 1;
  min-width: 0;
}

.stab__name {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.3;
  transition: color 0.25s ease;
}

.stab.is-active .stab__name {
  color: var(--accent);
}

.stab__sub {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-muted);
  line-height: 1.3;
}

/* ── Count badge ── */
.stab__badge {
  margin-left: auto;
  flex-shrink: 0;
  min-width: 28px;
  height: 24px;
  border-radius: 6px;
  background: transparent;
  border: 1px solid var(--bg-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 7px;
  font-size: 11px;
  font-weight: 700;
  color: var(--text-muted);
  transition: all 0.3s ease;
}

.stab.is-active .stab__badge {
  background: var(--accent-bg-solid);
  border-color: var(--accent-border-solid);
  color: var(--accent);
}

/* ── Emergency tab variant ── */
.stab--emergency {
  margin-top: 4px;
  background: var(--dark-bg-alt);
  border-radius: 10px;
  overflow: hidden;
}

.stab--emergency::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 10px;
  background: radial-gradient(ellipse at 20% 50%, rgba(74, 154, 106, 0.08) 0%, transparent 70%);
  pointer-events: none;
}

.stab--emergency .stab__name {
  color: var(--dark-text);
}

.stab--emergency .stab__sub {
  color: var(--dark-text-muted);
}

.stab--emergency .stab__icon {
  background: rgba(74, 154, 106, 0.15);
  border-color: rgba(74, 154, 106, 0.25);
}

.stab--emergency .stab__badge {
  background: rgba(74, 154, 106, 0.1);
  border-color: rgba(74, 154, 106, 0.2);
  color: var(--accent-light);
  font-size: 10px;
  min-width: 34px;
}

.stab--emergency:hover {
  background: var(--dark-bg-alt);
}

.stab--emergency.is-active {
  background: var(--dark-bg-alt);
  box-shadow: 0 0 20px rgba(74, 154, 106, 0.12);
}

.stab--emergency.is-active .stab__name {
  color: var(--accent-light);
}

.stab--emergency.is-active .stab__icon {
  background: var(--accent-light);
  border-color: var(--accent-light);
  box-shadow: 0 0 12px rgba(74, 154, 106, 0.3);
}

.stab--emergency.is-active .stab__badge {
  background: rgba(74, 154, 106, 0.15);
  border-color: rgba(74, 154, 106, 0.3);
  color: #fff;
}

/* ── Emergency panel variant ── */
.stabs__panel.is-emergency {
  background: var(--dark-bg-alt);
  border-color: rgba(74, 154, 106, 0.2);
}

.stabs__panel.is-emergency::before {
  background: radial-gradient(circle at top left, rgba(74, 154, 106, 0.08) 0%, transparent 70%);
}

.stabs__panel.is-emergency .stabs__panel-badge {
  background: rgba(74, 154, 106, 0.12);
  color: var(--accent-light);
}

.stabs__panel.is-emergency .stabs__panel-title {
  color: var(--dark-text);
}

.stabs__panel.is-emergency .stabs__panel-rule {
  background: linear-gradient(90deg, var(--accent-light), transparent);
}

.stabs__panel.is-emergency .stabs__panel-desc {
  color: var(--dark-text-secondary);
}

.stabs__panel.is-emergency .stabs__panel-points-label {
  color: var(--dark-text-muted);
}

.stabs__panel.is-emergency .stabs__panel-point-text {
  color: var(--dark-text-secondary);
}

.stabs__panel.is-emergency .stabs__panel-check {
  background: rgba(74, 154, 106, 0.12);
  border-color: rgba(74, 154, 106, 0.25);
}

.stabs__panel.is-emergency .stabs__panel-divider {
  background: rgba(74, 154, 106, 0.15);
}

.stabs__panel.is-emergency .stabs__panel-trust span {
  color: var(--dark-text-muted);
}

.stabs__panel.is-emergency .stabs__cta-primary {
  background: var(--accent-light);
  box-shadow: 0 0 16px rgba(74, 154, 106, 0.25);
}

.stabs__panel.is-emergency .stabs__cta-ghost {
  border-color: rgba(74, 154, 106, 0.25);
  color: var(--dark-text-secondary);
}

.stabs__panel.is-emergency .stabs__cta-ghost:hover {
  border-color: var(--accent-light);
  color: var(--dark-text);
}

/* ── Hide panel badge on homepage ── */
#stabs-section-home .stabs__panel-badge {
  display: none;
}

/* ── Homepage: tabs fill panel height without scroll ── */
#stabs-sidebar-home .stabs__list {
  max-height: none !important;
  overflow-y: visible;
}

#stabs-sidebar-home .stabs__fade {
  display: none;
}

/* ============================================================
   STABS — Adwokat 24 Emergency Override
   Dark theme, red accents, urgent atmosphere
   ============================================================ */

/* Section: dark emergency background with grid overlay */
#stabs-section-a24 {
  background: linear-gradient(to bottom, #0A0A0A 0%, #111111 30%, #0F0F0F 100%);
  position: relative;
  overflow: hidden;
}
#stabs-section-a24::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 100% 60% at 0% 0%, rgba(180,40,40,0.06) 0%, transparent 50%),
    radial-gradient(ellipse 80% 80% at 100% 100%, rgba(180,40,40,0.04) 0%, transparent 50%);
  pointer-events: none;
  z-index: 0;
}
#stabs-section-a24::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.012) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.012) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
  z-index: 0;
}
#stabs-section-a24 .stabs__container {
  position: relative;
  z-index: 1;
}

/* Header: light text, red eyebrow */
#stabs-section-a24 .stabs__eyebrow {
  color: #FF6B6B;
}
#stabs-section-a24 .stabs__heading {
  color: var(--emergency-text);
}

/* Grid: stretch so sidebar = panel height (desktop only) */
@media (min-width: 861px) {
  #stabs-section-a24 .stabs__grid {
    align-items: stretch;
  }
}

/* Sidebar: dark elevated card */
#stabs-sidebar-a24 {
  background: rgba(255,255,255,0.03);
  border-color: rgba(255,255,255,0.06);
}
@media (min-width: 861px) {
  #stabs-sidebar-a24 {
    display: flex;
    flex-direction: column;
  }
}
#stabs-sidebar-a24 .stabs__list {
  max-height: none !important;
  overflow-y: visible;
}
@media (min-width: 861px) {
  #stabs-sidebar-a24 .stabs__list {
    flex: 1;
    display: flex;
    flex-direction: column;
  }
}
#stabs-sidebar-a24 .stabs__fade {
  display: none;
}

/* Indicator bar: red */
#stabs-section-a24 .stabs__indicator {
  background: #DC3232;
}

/* All tabs in a24: dark emergency style */
#stabs-section-a24 .stab {
  background: transparent;
}
#stabs-section-a24 .stab::before {
  background: none;
}
#stabs-section-a24 .stab:hover {
  background: rgba(220,50,50,0.06);
}
#stabs-section-a24 .stab.is-active {
  background: rgba(220,50,50,0.08);
  box-shadow: 0 0 16px rgba(220,50,50,0.08);
}

/* Tab icon: red-tinted */
#stabs-section-a24 .stab__icon {
  background: rgba(220,50,50,0.08);
  border-color: rgba(220,50,50,0.2);
}
#stabs-section-a24 .stab__icon svg {
  stroke: #FF8A8A;
}
#stabs-section-a24 .stab.is-active .stab__icon {
  background: #DC3232;
  border-color: #DC3232;
  box-shadow: 0 0 12px rgba(220,50,50,0.3);
}
#stabs-section-a24 .stab.is-active .stab__icon svg {
  stroke: #fff;
}

/* Tab text: light on dark */
#stabs-section-a24 .stab__name {
  color: var(--dark-text);
}
#stabs-section-a24 .stab__sub {
  color: var(--dark-text-muted);
}
#stabs-section-a24 .stab.is-active .stab__name {
  color: #FF6B6B;
}

/* Panel: dark elevated, red accent details */
#stabs-section-a24 .stabs__panel {
  background: var(--dark-bg-alt);
  border-color: rgba(220,50,50,0.15);
}
#stabs-section-a24 .stabs__panel::before {
  background: radial-gradient(circle at top left, rgba(220,50,50,0.06) 0%, transparent 70%);
}
#stabs-section-a24 .stabs__panel-badge {
  background: rgba(220,50,50,0.12);
  color: #FF6B6B;
}
#stabs-section-a24 .stabs__panel-title {
  color: var(--emergency-text);
}
#stabs-section-a24 .stabs__panel-rule {
  background: linear-gradient(90deg, #DC3232, transparent);
}
#stabs-section-a24 .stabs__panel-desc {
  color: var(--dark-text-secondary);
}
#stabs-section-a24 .stabs__panel-points-label {
  color: var(--dark-text-muted);
}
#stabs-section-a24 .stabs__panel-point-text {
  color: var(--dark-text-secondary);
}
#stabs-section-a24 .stabs__panel-check {
  background: rgba(220,50,50,0.1);
  border-color: rgba(220,50,50,0.25);
}
#stabs-section-a24 .stabs__panel-check svg {
  stroke: #FF6B6B;
}
#stabs-section-a24 .stabs__panel-divider {
  background: rgba(220,50,50,0.15);
}
#stabs-section-a24 .stabs__panel-trust span {
  color: var(--dark-text-muted);
}
#stabs-section-a24 .stabs__cta-primary {
  background: #DC3232;
  box-shadow: 0 0 16px rgba(220,50,50,0.25);
}
#stabs-section-a24 .stabs__cta-primary:hover {
  background: #E04040;
  box-shadow: 0 0 24px rgba(220,50,50,0.35);
}
#stabs-section-a24 .stabs__cta-ghost {
  border-color: rgba(220,50,50,0.25);
  color: var(--dark-text-secondary);
}
#stabs-section-a24 .stabs__cta-ghost:hover {
  border-color: #FF6B6B;
  color: var(--dark-text);
}

/* ── Right column — panel ── */
.stabs__panel {
  background: var(--bg-elevated);
  border: 1px solid var(--bg-tertiary);
  border-radius: 14px;
  padding: clamp(28px, 3vw, 40px);
  box-shadow: var(--shadow-sm);
  position: relative;
  overflow: hidden;
}

.stabs__panel::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 80px;
  height: 80px;
  background: radial-gradient(circle at top left, rgba(46, 107, 71, 0.06) 0%, transparent 70%);
  pointer-events: none;
}

.stabs__panel-inner {
  position: relative;
  z-index: 1;
}

/* Staggered entrance for panel children */
.stabs__panel-inner > * {
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.4s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.stabs__panel-inner.is-visible > * {
  opacity: 1;
  transform: translateY(0);
}

.stabs__panel-inner.is-visible > *:nth-child(1) { transition-delay: 0.02s; }
.stabs__panel-inner.is-visible > *:nth-child(2) { transition-delay: 0.06s; }
.stabs__panel-inner.is-visible > *:nth-child(3) { transition-delay: 0.10s; }
.stabs__panel-inner.is-visible > *:nth-child(4) { transition-delay: 0.14s; }
.stabs__panel-inner.is-visible > *:nth-child(5) { transition-delay: 0.18s; }
.stabs__panel-inner.is-visible > *:nth-child(6) { transition-delay: 0.22s; }
.stabs__panel-inner.is-visible > *:nth-child(7) { transition-delay: 0.26s; }
.stabs__panel-inner.is-visible > *:nth-child(8) { transition-delay: 0.30s; }

/* ── Panel content ── */
.stabs__panel-badge {
  display: inline-block;
  padding: 4px 12px;
  border-radius: 100px;
  background: var(--accent-bg-solid);
  color: var(--accent);
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 12px;
}

.stabs__panel-title {
  font-family: var(--font-body);
  font-size: clamp(1.3rem, 1.1rem + 0.8vw, 1.75rem);
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.25;
  margin-bottom: 6px;
  letter-spacing: -0.01em;
}

.stabs__panel-rule {
  width: 36px;
  height: 2px;
  background: linear-gradient(90deg, var(--accent), var(--accent-light));
  border-radius: 2px;
  margin-bottom: 16px;
}

.stabs__panel-desc {
  font-family: var(--font-body);
  font-size: 15px;
  color: var(--text-secondary);
  line-height: 1.7;
  margin-bottom: 24px;
}

.stabs__panel-points-label {
  display: block;
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--text-muted);
  margin-bottom: 10px;
}

.stabs__panel-points {
  list-style: none;
  margin: 0 0 24px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.stabs__panel-point {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.stabs__panel-check {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  min-width: 24px;
  border-radius: 6px;
  background: var(--accent-bg-solid);
  border: 1px solid var(--accent-border-solid);
  margin-top: 1px;
}

.stabs__panel-check svg {
  width: 14px;
  height: 14px;
  stroke: var(--accent);
}

.stabs__panel-point-text {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text-secondary);
  line-height: 1.6;
}

.stabs__panel-divider {
  width: 100%;
  height: 1px;
  background: var(--bg-tertiary);
  margin: 0 0 20px;
}

.stabs__panel-trust {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 24px;
}

.stabs__panel-trust svg {
  width: 14px;
  height: 14px;
  stroke: var(--accent);
  flex-shrink: 0;
}

.stabs__panel-trust span {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text-muted);
}

.stabs__panel-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.stabs__cta-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 24px;
  background: var(--accent);
  color: #fff;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 700;
  border-radius: 8px;
  border: none;
  cursor: pointer;
  transition: all 0.3s ease;
  text-decoration: none;
}

.stabs__cta-primary svg {
  width: 16px;
  height: 16px;
  stroke: #fff;
  transition: transform 0.3s ease;
}

.stabs__cta-primary:hover {
  background: var(--accent-hover);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(46, 107, 71, 0.25);
}

.stabs__cta-primary:hover svg {
  transform: translateX(3px);
}

.stabs__cta-ghost {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 24px;
  background: transparent;
  color: var(--text-secondary);
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  border-radius: 8px;
  border: 1px solid var(--bg-tertiary);
  cursor: pointer;
  transition: all 0.3s ease;
  text-decoration: none;
}

.stabs__cta-ghost svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
}

.stabs__cta-ghost:hover {
  border-color: var(--accent);
  color: var(--text-primary);
  transform: translateY(-2px);
}

/* ============================================================
   STABS — Tablet (860–1100px)
   ============================================================ */

@media (max-width: 1100px) and (min-width: 861px) {
  .stabs__grid {
    grid-template-columns: 240px 1fr;
  }
  .stab__badge {
    display: none;
  }
  .stab__sub {
    display: none;
  }
  .stabs__panel {
    padding: 24px;
  }
  .stabs__panel-point:nth-child(n+3) {
    display: none;
  }
}

/* ============================================================
   STABS — Mobile (< 860px) — Accordion
   ============================================================ */

@media (max-width: 860px) {
  .stabs__grid {
    display: block;
  }

  .stabs__sidebar,
  .stabs__panel {
    display: none;
  }

  /* Accordion */
  .stabs-acc {
    display: flex;
    flex-direction: column;
    gap: 0;
  }

  .stabs-acc__item {
    margin-bottom: 8px;
  }

  .stabs-acc__trigger {
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
    padding: 16px 20px;
    background: var(--bg-elevated);
    border: 1px solid var(--bg-tertiary);
    border-radius: 12px;
    cursor: pointer;
    transition: all 0.3s ease;
    text-align: left;
    font-family: var(--font-body);
  }

  .stabs-acc__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    min-width: 32px;
    border-radius: 8px;
    background: var(--accent-bg-solid);
    border: 1px solid var(--accent-border-solid);
    transition: all 0.3s ease;
  }

  .stabs-acc__icon svg {
    width: 16px;
    height: 16px;
    stroke: var(--accent);
    transition: stroke 0.3s ease;
  }

  .stabs-acc__text {
    flex: 1;
    min-width: 0;
  }

  .stabs-acc__name {
    display: block;
    font-size: 15px;
    font-weight: 600;
    color: var(--text-primary);
    line-height: 1.3;
  }

  .stabs-acc__sub {
    display: block;
    font-size: 12px;
    font-weight: 500;
    color: var(--text-muted);
    line-height: 1.3;
    margin-top: 1px;
  }

  .stabs-acc__chevron {
    width: 18px;
    height: 18px;
    stroke: var(--text-muted);
    fill: none;
    stroke-width: 2;
    flex-shrink: 0;
    transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1), stroke 0.3s ease;
  }

  /* Active trigger */
  .stabs-acc__trigger[aria-expanded="true"] {
    border-left: 3px solid var(--accent);
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
    border-bottom-color: transparent;
    background: var(--accent-bg-solid);
  }

  .stabs-acc__trigger[aria-expanded="true"] .stabs-acc__icon {
    background: var(--accent);
    border-color: var(--accent);
  }

  .stabs-acc__trigger[aria-expanded="true"] .stabs-acc__icon svg {
    stroke: #fff;
  }

  .stabs-acc__trigger[aria-expanded="true"] .stabs-acc__name {
    color: var(--accent);
  }

  .stabs-acc__trigger[aria-expanded="true"] .stabs-acc__chevron {
    transform: rotate(180deg);
    stroke: var(--accent);
  }

  .stabs-acc__trigger:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: -2px;
  }

  /* Accordion panel */
  .stabs-acc__panel {
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transition: max-height 0.45s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.3s ease 0.05s;
  }

  .stabs-acc__panel.is-open {
    opacity: 1;
  }

  .stabs-acc__panel-body {
    padding: 20px;
    background: var(--bg-elevated);
    border: 1px solid var(--bg-tertiary);
    border-top: none;
    border-bottom-left-radius: 12px;
    border-bottom-right-radius: 12px;
  }

  /* Stack CTAs vertically on mobile */
  .stabs-acc__panel-body .stabs__panel-ctas {
    flex-direction: column;
  }

  .stabs-acc__panel-body .stabs__cta-primary,
  .stabs-acc__panel-body .stabs__cta-ghost {
    width: 100%;
    justify-content: center;
  }

  /* ── Adwokat 24 — Emergency accordion override ── */

  #stabs-section-a24 .stabs-acc__trigger {
    background: rgba(255,255,255,0.03);
    border-color: rgba(255,255,255,0.06);
  }
  #stabs-section-a24 .stabs-acc__trigger:hover {
    background: rgba(220,50,50,0.06);
    border-color: rgba(220,50,50,0.15);
  }
  #stabs-section-a24 .stabs-acc__icon {
    background: rgba(220,50,50,0.08);
    border-color: rgba(220,50,50,0.2);
  }
  #stabs-section-a24 .stabs-acc__icon svg {
    stroke: #FF8A8A;
  }
  #stabs-section-a24 .stabs-acc__name {
    color: var(--dark-text);
  }
  #stabs-section-a24 .stabs-acc__sub {
    color: var(--dark-text-muted);
  }
  #stabs-section-a24 .stabs-acc__chevron {
    stroke: #FF6B6B;
    color: #FF6B6B;
  }
  #stabs-section-a24 .stabs-acc__chevron svg {
    stroke: #FF6B6B;
  }

  /* Active trigger */
  #stabs-section-a24 .stabs-acc__trigger[aria-expanded="true"] {
    border-left-color: #DC3232;
    border-bottom-color: transparent;
    background: rgba(220,50,50,0.08);
  }
  #stabs-section-a24 .stabs-acc__trigger[aria-expanded="true"] .stabs-acc__icon {
    background: #DC3232;
    border-color: #DC3232;
    box-shadow: 0 0 10px rgba(220,50,50,0.3);
  }
  #stabs-section-a24 .stabs-acc__trigger[aria-expanded="true"] .stabs-acc__icon svg {
    stroke: #fff;
  }
  #stabs-section-a24 .stabs-acc__trigger[aria-expanded="true"] .stabs-acc__name {
    color: #FF6B6B;
  }
  #stabs-section-a24 .stabs-acc__trigger[aria-expanded="true"] .stabs-acc__chevron {
    stroke: #FF6B6B;
    color: #FF6B6B;
    transform: rotate(180deg);
  }
  #stabs-section-a24 .stabs-acc__trigger[aria-expanded="true"] .stabs-acc__chevron svg {
    stroke: #FF6B6B;
  }
  #stabs-section-a24 .stabs-acc__trigger:focus-visible {
    outline-color: #FF6B6B;
  }

  /* Panel body */
  #stabs-section-a24 .stabs-acc__panel-body {
    background: rgba(13,13,13,0.95);
    border-color: rgba(255,255,255,0.06);
    border-top: none;
  }

  /* Panel content overrides */
  #stabs-section-a24 .stabs__panel-title {
    color: var(--emergency-text);
  }
  #stabs-section-a24 .stabs__panel-badge {
    background: rgba(220,50,50,0.12);
    color: #FF6B6B;
  }
  #stabs-section-a24 .stabs__panel-rule {
    background: linear-gradient(90deg, #DC3232, transparent);
  }
  #stabs-section-a24 .stabs__panel-desc {
    color: var(--dark-text-secondary);
  }
  #stabs-section-a24 .stabs__panel-points-label {
    color: var(--dark-text-muted);
  }
  #stabs-section-a24 .stabs__panel-point-text {
    color: var(--dark-text-secondary);
  }
  #stabs-section-a24 .stabs__panel-check {
    background: rgba(220,50,50,0.1);
    border-color: rgba(220,50,50,0.25);
  }
  #stabs-section-a24 .stabs__panel-check svg {
    stroke: #FF6B6B;
  }
  #stabs-section-a24 .stabs__panel-divider {
    background: rgba(220,50,50,0.15);
  }
  #stabs-section-a24 .stabs__panel-trust span {
    color: var(--dark-text-muted);
  }
  #stabs-section-a24 .stabs__cta-primary {
    background: #DC3232;
    box-shadow: 0 0 16px rgba(220,50,50,0.25);
  }
  #stabs-section-a24 .stabs__cta-primary:hover {
    background: #E04040;
  }
  #stabs-section-a24 .stabs__cta-ghost {
    border-color: rgba(220,50,50,0.25);
    color: var(--dark-text-secondary);
  }
  #stabs-section-a24 .stabs__cta-ghost:hover {
    border-color: #FF6B6B;
    color: var(--dark-text);
  }
}

/* ============================================================
   EXPERT — Treść ekspercka + Sidebar TOC
   ============================================================ */

.expert {
  padding: clamp(32px, 3vw, 48px) 0 clamp(64px, 7vw, 112px);
}

.expert__container {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 clamp(20px, 12px + 3vw, 96px);
}

/* ── Nagłówek sekcji ── */
.expert__header {
  text-align: center;
  max-width: 700px;
  margin: 0 auto clamp(40px, 5vw, 64px);
}

.expert__eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
}

.expert__headline {
  font-family: var(--font-display);
  font-size: clamp(2rem, 1.5rem + 2.5vw, 3rem);
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.15;
}

.expert__headline em {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--accent);
  font-weight: 500;
}

/* ── Content + Sidebar grid ── */
.expert__grid {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: clamp(32px, 3.5vw, 56px);
  align-items: start;
}

/* ── Sidebar (TOC) ── */
.expert__sidebar {
  position: sticky;
  top: 76px;
}

.toc {
  background: var(--bg-elevated);
  border: 1px solid var(--bg-tertiary);
  border-radius: 14px;
  padding: 24px;
  box-shadow: var(--shadow-sm);
}

.toc__title {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--accent);
  padding-bottom: 12px;
  border-bottom: 1px solid var(--bg-tertiary);
  margin-bottom: 16px;
}

.toc__list {
  list-style: none;
  border-left: 2px solid var(--bg-tertiary);
  padding-left: 0;
}

.toc__link {
  display: block;
  padding: 8px 0 8px 16px;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-muted);
  text-decoration: none;
  border-left: 2px solid transparent;
  margin-left: -2px;
  transition: color 0.25s ease, border-left-color 0.25s ease, transform 0.25s ease;
}

.toc__link:hover {
  color: var(--text-secondary);
  transform: translateX(4px);
  border-left-color: var(--accent-border-solid);
}

.toc__link.is-active {
  color: var(--accent);
  font-weight: 600;
  border-left-color: var(--accent);
  transform: translateX(0);
}

/* Sidebar CTA */
.toc__cta {
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid var(--bg-tertiary);
  text-align: center;
}

.toc__cta-phone {
  display: block;
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--accent);
  text-decoration: none;
  margin-bottom: 4px;
  transition: color 0.3s ease;
}

.toc__cta-phone:hover {
  color: var(--accent-hover);
}

.toc__cta-label {
  font-size: 11px;
  color: var(--text-muted);
  font-weight: 600;
}

/* ── Sidebar Mini Form ── */
.sidebar-form {
  margin-top: 20px;
  background: var(--bg-elevated);
  border: 1px solid var(--bg-tertiary);
  border-radius: 14px;
  padding: 24px;
  box-shadow: var(--shadow-sm);
}

.sidebar-form__title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 6px;
}

.sidebar-form__desc {
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.5;
  margin-bottom: 16px;
}

.sidebar-form__form {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.sidebar-form__input,
.sidebar-form__textarea {
  width: 100%;
  padding: 10px 14px;
  border: 1px solid var(--bg-tertiary);
  border-radius: 8px;
  background: var(--bg-primary);
  color: var(--text-primary);
  font-family: var(--font-body);
  font-size: 13px;
  transition: border-color 0.25s ease, box-shadow 0.25s ease;
  box-sizing: border-box;
}

.sidebar-form__input::placeholder,
.sidebar-form__textarea::placeholder {
  color: var(--text-muted);
}

.sidebar-form__input:focus,
.sidebar-form__textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-bg-solid);
}

.sidebar-form__textarea {
  resize: vertical;
  min-height: 60px;
}

.sidebar-form__btn {
  display: block;
  width: 100%;
  padding: 11px 16px;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.25s ease, transform 0.15s ease;
}

.sidebar-form__btn:hover {
  background: var(--accent-hover);
  transform: translateY(-1px);
}

.sidebar-form__btn:active {
  transform: translateY(0);
}

.sidebar-form__privacy {
  font-size: 10px;
  color: var(--text-muted);
  text-align: center;
  margin-top: 10px;
  margin-bottom: 0;
}

/* ── Main content ── */
.expert__main {
  max-width: 100%;
  min-width: 0;
}

/* ── Segment ── */
.segment {
  padding: clamp(16px, 2vw, 24px) 0;
  position: relative;
  scroll-margin-top: 120px;
}

.segment + .segment {
  border-top: none;
}

/* Alternujące tło */
.segment:nth-child(odd) .segment__inner {
  background: transparent;
}

.segment:nth-child(even) .segment__inner {
  background: var(--bg-primary);
  border-radius: 14px;
  padding: clamp(24px, 3vw, 36px);
  border: 1px solid var(--bg-tertiary);
}

/* Gdy segment--dark jest parzyste dziecko, wyłącz kartę z inner — dark sam jest kartą */
.segment--dark:nth-child(even) .segment__inner {
  background: transparent;
  border-radius: 0;
  padding: 0;
  border: none;
}


/* ── Nagłówek segmentu ── */
.segment__head {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 20px;
}

.segment__icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: var(--accent-bg-solid);
  border: 1px solid var(--accent-border-solid);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.segment__icon svg {
  width: 20px;
  height: 20px;
  stroke: var(--accent);
  fill: none;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.segment__title {
  font-family: var(--font-body);
  font-size: clamp(1.25rem, 1.1rem + 0.7vw, 1.6rem);
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.25;
}

/* ── Treść segmentu ── */
.segment__body {
  font-size: 15px;
  color: var(--text-secondary);
  line-height: 1.8;
}

.segment__body p {
  margin-bottom: 16px;
}

.segment__body p:last-child {
  margin-bottom: 0;
}

.segment__body strong {
  font-weight: 600;
  color: var(--text-primary);
}

.segment__body a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: var(--accent-border-solid);
  transition: color 0.2s ease;
}

.segment__body a:hover {
  color: var(--accent-hover);
}

/* Lista w treści */
.segment__body ul {
  list-style: none;
  padding-left: 0;
  margin: 16px 0;
}

.segment__body ul li {
  position: relative;
  padding-left: 24px;
  margin-bottom: 8px;
  font-size: 14px;
}

.segment__body ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 8px;
  width: 8px;
  height: 8px;
  border-radius: 2px;
  background: var(--accent-bg-solid);
  border: 1.5px solid var(--accent-border-solid);
}

/* ── Badge artykułu KK/KPK ── */
.kk-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 4px;
  background: var(--accent-bg-solid);
  border: 1px solid var(--accent-border-solid);
  font-size: 12px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  white-space: nowrap;
}

/* Only interactive badges (links) get hover */
a.kk-badge:hover {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
  text-decoration: none;
}

/* ── Inline CTA ── */
.inline-cta {
  background: var(--bg-elevated);
  border: 1px solid var(--accent-border-solid);
  border-radius: 14px;
  padding: clamp(24px, 3vw, 32px);
  box-shadow: var(--shadow-sm);
  display: flex;
  align-items: center;
  gap: 20px;
  margin: clamp(16px, 2vw, 24px) 0;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.inline-cta:hover {
  border-color: var(--accent);
  box-shadow: var(--shadow-md);
}

.inline-cta__icon {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  background: var(--accent-bg-solid);
  border: 1px solid var(--accent-border-solid);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.inline-cta__icon svg {
  width: 22px;
  height: 22px;
  stroke: var(--accent);
  fill: none;
  stroke-width: 1.5;
}

.inline-cta__text {
  flex: 1;
}

.inline-cta__title {
  font-size: 16px;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 4px;
}

.inline-cta__desc {
  font-size: 13px;
  color: var(--text-tertiary);
  line-height: 1.5;
}

.inline-cta__phone {
  font-family: var(--font-body);
  font-size: clamp(1rem, 0.9rem + 0.5vw, 1.2rem);
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--accent);
  text-decoration: none;
  white-space: nowrap;
  transition: color 0.3s ease;
  flex-shrink: 0;
}

.inline-cta__phone:hover {
  color: var(--accent-hover);
}

/* ── Scroll reveal ── */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ── Expert section responsive ── */
@media (max-width: 960px) {
  .expert__grid {
    grid-template-columns: 1fr;
  }

  .expert__sidebar {
    position: static;
    order: -1;
  }

  .toc {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    padding: 16px 20px;
  }

  .toc__title {
    border-bottom: none;
    padding-bottom: 0;
    margin-bottom: 0;
    margin-right: 12px;
  }

  .toc__list {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    border-left: none;
  }

  .toc__link {
    padding: 6px 14px;
    border-left: none;
    margin-left: 0;
    border-radius: 100px;
    border: 1px solid var(--bg-tertiary);
    font-size: 12px;
  }

  .toc__link:hover {
    transform: none;
    border-color: var(--accent-border-solid);
    background: var(--accent-bg-solid);
  }

  .toc__link.is-active {
    border-left: none;
    background: var(--accent);
    color: #fff;
    border-color: var(--accent);
  }

  .toc__cta {
    display: none;
  }

  .sidebar-form {
    display: none;
  }
}

@media (max-width: 600px) {
  .inline-cta {
    flex-direction: column;
    text-align: center;
  }

  .segment:nth-child(even) .segment__inner {
    padding: 20px 16px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .reveal {
    opacity: 1 !important;
    transform: none !important;
  }
}

/* ============================================================
   SUBHERO — Podkategoria kryminalna (podstrona typu /zabojstwo)
   Prefix: subhero-
   ============================================================ */

.subhero {
  position: relative;
  background: var(--dark-bg);
  padding: clamp(100px, 10vw, 150px) 0 clamp(56px, 6vw, 80px);
  overflow: hidden;
}

/* Radial gradient decorative glow */
.subhero::before {
  content: '';
  position: absolute;
  top: -20%;
  right: -10%;
  width: 700px;
  height: 700px;
  background: radial-gradient(circle, rgba(46,107,71,0.04) 0%, transparent 60%);
  pointer-events: none;
}

/* Accent top line */
.subhero-topline {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--accent-light), var(--accent), var(--accent-light), transparent);
  opacity: 0.5;
}

/* Grid: 55/45 split — text left, media right */
.subhero-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: clamp(32px, 4vw, 72px);
  align-items: center;
}

/* ── Text column ── */
.subhero-content {
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* ── Media column (photo / video placeholder) ── */
.subhero-media {
  position: relative;
  align-self: stretch;
  z-index: 1;
}
.subhero-media__frame {
  position: relative;
  height: 100%;
  min-height: 480px;
  overflow: hidden;
  border-radius: 14px;
  background: var(--dark-bg-elevated);
  border: 1px solid var(--dark-border);
}
.subhero-media__frame img,
.subhero-media__frame video {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 15%;
  transition: transform 2.5s cubic-bezier(0.16, 1, 0.3, 1);
}
.subhero-media__frame:hover img,
.subhero-media__frame:hover video {
  transform: scale(1.03);
}

/* Placeholder state — visible until replaced with real media */
.subhero-media__placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  background:
    radial-gradient(ellipse 60% 50% at 50% 40%, rgba(46,107,71,0.06) 0%, transparent 70%),
    var(--dark-bg-elevated);
}
.subhero-media__placeholder svg {
  stroke: var(--dark-border);
  opacity: 0.5;
}
.subhero-media__placeholder span {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--dark-text-muted);
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

/* ── 1. Breadcrumb ── */
.subhero-breadcrumb {
  margin-bottom: 24px;
}
.subhero-breadcrumb ol {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0;
  list-style: none;
  padding: 0;
  margin: 0;
}
.subhero-breadcrumb li {
  display: flex;
  align-items: center;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  color: var(--dark-text-muted);
}
.subhero-breadcrumb li + li::before {
  content: '›';
  margin: 0 6px;
  font-size: 10px;
  color: var(--dark-border);
  font-weight: 400;
}
.subhero-breadcrumb a {
  color: var(--dark-text-muted);
  text-decoration: none;
  transition: color 0.2s ease;
}
.subhero-breadcrumb a:hover {
  color: var(--dark-text);
}
.subhero-breadcrumb li[aria-current="page"] span {
  color: var(--dark-text-secondary);
}

/* ── 2. Eyebrow badge ── */
.subhero-eyebrow {
  margin-bottom: 20px;
}
.subhero-eyebrow span {
  display: inline-flex;
  align-items: center;
  padding: 6px 16px;
  border-radius: 100px;
  background: rgba(46,107,71,0.08);
  border: 1px solid rgba(46,107,71,0.18);
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--accent-light);
}

/* ── 3. H1 ── */
.subhero-heading {
  font-family: var(--font-display);
  font-size: clamp(2.1rem, 1.5rem + 3vw, 3.4rem);
  font-weight: 700;
  color: var(--dark-text);
  line-height: 1.08;
  letter-spacing: -0.025em;
  margin-bottom: var(--space-3);
}
.subhero-heading em {
  font-family: var(--font-display);
  font-style: normal;
  font-weight: 500;
  color: var(--accent-light);
}

/* ── 4. Quick-answer box ── */
.subhero-answer {
  background: var(--dark-bg-elevated);
  border-left: 3px solid var(--accent-light);
  border-radius: 0 12px 12px 0;
  padding: 20px 24px;
  max-width: 640px;
  margin: 0 0 24px;
  position: relative;
}
.subhero-answer p {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 400;
  color: var(--dark-text-secondary);
  line-height: 1.7;
  margin: 0;
}
.subhero-answer strong {
  font-weight: 600;
  color: var(--dark-text);
}
.subhero-answer__badge {
  display: inline-block;
  background: rgba(74,154,106,0.12);
  border: 1px solid rgba(74,154,106,0.2);
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 12px;
  font-weight: 600;
  color: var(--accent-light);
}

/* ── 5. Testimonial ── */
.subhero-testimonials {
  margin-bottom: var(--space-4);
}

/* ── 6. CTA ── */
.subhero-ctas {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 24px;
}
.subhero-ctas .btn-accent svg,
.subhero-ctas .btn-ghost-dark svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
}
.subhero-ctas .btn-accent:focus-visible,
.subhero-ctas .btn-ghost-dark:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
}

/* ── 7. Trust bar ── */
.subhero-trust {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
  font-size: 13px;
  color: var(--dark-text-muted);
}
.subhero-trust__item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
}
.subhero-trust__item svg {
  stroke: var(--accent-light);
  flex-shrink: 0;
}
.subhero-trust__sep {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: var(--dark-border);
  flex-shrink: 0;
}

/* ── 8. Emergency crosslink strip ── */
.subhero-emergency {
  margin-top: 28px;
  max-width: 640px;
}
.subhero-emergency__link {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  background: var(--dark-bg-alt);
  border-radius: 12px;
  padding: 14px 24px;
  text-decoration: none;
  transition: background 0.2s ease;
}
.subhero-emergency__link:hover {
  background: #141414;
}
.subhero-emergency__text {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--emergency-accent);
}
.subhero-emergency__cta {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 700;
  color: var(--emergency-text);
  text-decoration: none;
  transition: text-decoration 0.2s ease;
  white-space: nowrap;
}
.subhero-emergency__link:hover .subhero-emergency__cta {
  text-decoration: underline;
}

/* ── Entrance animation states ── */
.subhero-anim {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}
.subhero-anim--y20 {
  transform: translateY(20px);
}
.subhero-anim--y12 {
  transform: translateY(12px);
}
.subhero-anim.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Media column entrance — slide from right */
.subhero-media.subhero-anim {
  opacity: 0;
  transform: translateX(40px);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}
.subhero-media.subhero-anim.is-visible {
  opacity: 1;
  transform: translateX(0);
}

/* Cascade delays */
.subhero-anim[data-subhero-delay="1"] { transition-delay: 0.06s; }
.subhero-anim[data-subhero-delay="2"] { transition-delay: 0.12s; }
.subhero-anim[data-subhero-delay="3"] { transition-delay: 0.18s; }
.subhero-anim[data-subhero-delay="4"] { transition-delay: 0.24s; }
.subhero-anim[data-subhero-delay="5"] { transition-delay: 0.30s; }
.subhero-anim[data-subhero-delay="6"] { transition-delay: 0.36s; }
.subhero-anim[data-subhero-delay="7"] { transition-delay: 0.42s; }

/* ── Responsive: Tablet ── */
@media (max-width: 960px) {
  .subhero-grid {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }
  .subhero-content {
    text-align: center;
    align-items: center;
  }
  .subhero-breadcrumb ol {
    justify-content: center;
  }
  .subhero-lead {
    margin-left: auto;
    margin-right: auto;
  }
  .subhero-answer {
    margin-left: auto;
    margin-right: auto;
  }
  .subhero-ctas {
    justify-content: center;
  }
  .subhero-trust {
    justify-content: center;
  }
  .subhero-emergency {
    margin-left: auto;
    margin-right: auto;
  }
  .subhero-emergency__link {
    justify-content: center;
  }
  .subhero-media__frame {
    min-height: 360px;
  }
}

/* ── Responsive: Mobile ── */
@media (max-width: 767px) {
  .subhero-ctas {
    flex-direction: column;
    width: 100%;
  }
  .subhero-ctas .btn-accent,
  .subhero-ctas .btn-ghost-dark {
    width: 100%;
    justify-content: center;
    min-height: 48px;
  }
  .subhero-trust {
    font-size: 12px;
    gap: 10px;
  }
  .subhero-emergency__link {
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
    padding: 14px 16px;
  }
  .subhero-answer {
    padding: 16px 18px;
  }
  .subhero-media__frame {
    min-height: 280px;
  }
}

/* Reduced motion: skip entrance animations */
@media (prefers-reduced-motion: reduce) {
  .subhero-anim {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

/* ============================================================
   SUBSTRIP — 4-kolumnowy horizontal strip faktów
   Bezpośrednio pod subhero, above-the-fold
   ============================================================ */

.substrip {
  position: relative;
  background: var(--bg-primary);
  padding: 32px 0;
}

/* Accent top line — visual bridge from hero */
.substrip__topline {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent 5%, var(--accent-border-solid) 30%, var(--accent-border-solid) 70%, transparent 95%);
}

.substrip__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}

/* ── Column ── */
.substrip__col {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 8px;
  padding: 12px clamp(16px, 2vw, 32px);
  border-radius: 10px;
  overflow: hidden;
  transition: background 0.35s cubic-bezier(0.16, 1, 0.3, 1);
}
.substrip__col:hover {
  background: var(--accent-bg);
}
.substrip__col:hover .substrip__icon {
  transform: scale(1.05);
  border-color: var(--accent-light);
  box-shadow: 0 0 0 3px rgba(46,107,71,0.08);
}
.substrip__col:hover .substrip__watermark {
  opacity: 0.06;
}

/* ── Step number ── */
.substrip__step {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  color: var(--accent-light);
  letter-spacing: 1px;
  opacity: 0.6;
}

/* ── Icon ── */
.substrip__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 8px;
  background: var(--accent-bg-solid);
  border: 1px solid var(--accent-border-solid);
  flex-shrink: 0;
  transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1),
              border-color 0.35s ease,
              box-shadow 0.35s ease;
}
.substrip__icon svg {
  stroke: var(--accent);
}

/* ── Text ── */
.substrip__text {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.4;
}

/* ── Watermark (large background icon) ── */
.substrip__watermark {
  position: absolute;
  bottom: -8px;
  right: -4px;
  opacity: 0.03;
  stroke: var(--accent);
  pointer-events: none;
  transition: opacity 0.35s ease;
}

/* ── Connector arrow between columns ── */
.substrip__connector {
  position: absolute;
  right: -10px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
}
.substrip__connector svg {
  width: 14px;
  height: 14px;
  stroke: var(--accent-border-solid);
}

/* ── Dark variant ── */
.substrip--dark {
  background: var(--dark-bg);
}
.substrip--dark .substrip__topline {
  background: linear-gradient(90deg, transparent 5%, var(--dark-border) 30%, var(--dark-border) 70%, transparent 95%);
}
.substrip--dark .substrip__step {
  color: var(--accent-light);
  opacity: 0.4;
}
.substrip--dark .substrip__icon {
  background: rgba(46,107,71,0.1);
  border-color: rgba(46,107,71,0.2);
}
.substrip--dark .substrip__icon svg {
  stroke: var(--accent-light);
}
.substrip--dark .substrip__text {
  color: var(--dark-text);
}
.substrip--dark .substrip__watermark {
  stroke: var(--accent-light);
  opacity: 0.02;
}
.substrip--dark .substrip__connector svg {
  stroke: var(--dark-border);
}
.substrip--dark .substrip__col:hover {
  background: rgba(46,107,71,0.06);
}
.substrip--dark .substrip__col:hover .substrip__icon {
  border-color: var(--accent-light);
  box-shadow: 0 0 0 3px rgba(74,154,106,0.1);
}
.substrip--dark .substrip__col:hover .substrip__watermark {
  opacity: 0.05;
}

/* ── Tablet (768–960) ── */
@media (max-width: 960px) {
  .substrip__icon {
    width: 32px;
    height: 32px;
  }
  .substrip__icon svg {
    width: 16px;
    height: 16px;
  }
  .substrip__text {
    font-size: 12px;
  }
  .substrip__connector {
    right: -8px;
  }
  .substrip__connector svg {
    width: 12px;
    height: 12px;
  }
  .substrip__watermark {
    width: 60px;
    height: 60px;
  }
}

/* ── Mobile (< 768) ── */
@media (max-width: 767px) {
  .substrip {
    padding: 0;
    background: var(--bg-tertiary);
  }
  .substrip--dark {
    background: var(--dark-border);
  }
  .substrip__topline {
    display: none;
  }
  .substrip__grid {
    grid-template-columns: 1fr 1fr;
    gap: 1px;
  }
  .substrip__col {
    flex-direction: row;
    text-align: left;
    gap: 12px;
    padding: 16px 14px;
    background: var(--bg-primary);
    border-radius: 0;
  }
  .substrip--dark .substrip__col {
    background: var(--dark-bg);
  }
  .substrip__step {
    display: none;
  }
  .substrip__icon {
    width: 32px;
    height: 32px;
    flex-shrink: 0;
  }
  .substrip__icon svg {
    width: 16px;
    height: 16px;
  }
  .substrip__text {
    font-size: 12px;
  }
  .substrip__connector {
    display: none;
  }
  .substrip__watermark {
    display: none;
  }
}

/* ============================================================
   EXPERT CONVERSION ENHANCEMENTS
   Nowe klasy — nie modyfikują istniejących .segment, .inline-cta
   ============================================================ */

/* ── 1. segment--dark: wyróżniony segment z subteln. tłem ── */
.segment--dark {
  background: var(--bg-secondary);
  border-radius: 16px;
  padding: clamp(20px, 2.5vw, 28px) clamp(24px, 3vw, 32px);
  border: 1px solid var(--border);
}
.segment--dark .segment__title {
  color: var(--text-primary);
}
.segment--dark .segment__body h4 {
  color: var(--text-primary);
}

/* ── 2. Penalty highlight cards ── */
.penalty-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin: 24px 0;
}
.penalty-card {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 24px 20px;
  text-align: center;
  position: relative;
  overflow: hidden;
  transition: box-shadow 0.3s ease, border-color 0.3s ease;
}
.penalty-card:hover {
  box-shadow: var(--shadow-md);
}
.penalty-card--severe {
  border-color: rgba(180,60,60,0.3);
  border-top: 3px solid rgba(180,60,60,0.5);
}
.penalty-card--mitigated {
  border-color: var(--accent-border-solid);
  border-top: 3px solid var(--accent-light);
}
.penalty-card__header {
  margin-bottom: 16px;
}
.penalty-card__badge {
  display: inline-block;
  background: var(--accent-bg);
  border: 1px solid var(--accent-border);
  padding: 3px 10px;
  border-radius: 4px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  color: var(--accent);
  margin-bottom: 8px;
}
.penalty-card--severe .penalty-card__badge {
  background: rgba(180,60,60,0.06);
  border-color: rgba(180,60,60,0.15);
  color: #B43C3C;
}
.penalty-card__title {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin: 0;
}
.penalty-card__penalty {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 1.4rem + 1.5vw, 2.4rem);
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.1;
  margin-bottom: 4px;
}
.penalty-card--severe .penalty-card__penalty {
  color: #B43C3C;
}
.penalty-card--mitigated .penalty-card__penalty {
  color: var(--accent);
}
.penalty-card__max {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--text-tertiary);
  margin-bottom: 14px;
}
.penalty-card__desc {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 400;
  color: var(--text-tertiary);
  line-height: 1.55;
  margin: 0;
}

@media (max-width: 767px) {
  .penalty-cards {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .penalty-card {
    padding: 20px 16px;
  }
  .penalty-card--severe,
  .penalty-card--mitigated {
    border-top-width: 3px;
  }
  .segment--dark {
    border-radius: 12px;
  }
}

/* ── 3. Segment stat pullquote ── */
.segment__stat {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin: 24px 0 0;
  padding: 16px 20px;
  background: var(--accent-bg-solid);
  border-left: 3px solid var(--accent);
  border-radius: 0 10px 10px 0;
}
.segment__stat-icon {
  flex-shrink: 0;
  margin-top: 1px;
}
.segment__stat-icon svg {
  stroke: var(--accent);
}
.segment__stat p {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 400;
  color: var(--text-secondary);
  line-height: 1.6;
  margin: 0;
}
.segment__stat p strong {
  color: var(--text-primary);
  font-weight: 600;
}

/* ── 4. Trust callout (inside segment body) ── */
.segment__trust-callout {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin: 24px 0;
  padding: 20px 24px;
  background: var(--accent-bg-solid);
  border: 1px solid var(--accent-border-solid);
  border-radius: 12px;
}
.segment__trust-callout-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  flex: 1;
  gap: 4px;
}
.segment__trust-callout-number {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 1.2rem + 1vw, 2rem);
  font-weight: 700;
  color: var(--accent);
  line-height: 1;
}
.segment__trust-callout-label {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 500;
  color: var(--text-tertiary);
  line-height: 1.4;
}
.segment__trust-callout-sep {
  width: 1px;
  height: 40px;
  background: var(--accent-border-solid);
  flex-shrink: 0;
}

@media (max-width: 767px) {
  .segment__trust-callout {
    flex-direction: column;
    gap: 16px;
    padding: 16px;
  }
  .segment__trust-callout-sep {
    width: 60px;
    height: 1px;
  }
}

/* ── 5. inline-cta--urgent variant ── */
.inline-cta--urgent {
  border-color: rgba(220,80,80,0.2);
  background: linear-gradient(135deg, rgba(220,80,80,0.03) 0%, var(--bg-primary) 60%);
}
.inline-cta--urgent .inline-cta__icon svg {
  stroke: #D66;
}

/* ── 6. Expert bottom CTA block ── */
.expert__bottom-cta {
  margin-top: var(--space-5);
  padding: clamp(28px, 3vw, 40px);
  background: var(--dark-bg);
  border-radius: 16px;
  border: 1px solid var(--dark-border);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.expert__bottom-cta::before {
  content: '';
  position: absolute;
  top: -50%;
  left: 50%;
  transform: translateX(-50%);
  width: 500px;
  height: 500px;
  background: radial-gradient(circle, rgba(46,107,71,0.06) 0%, transparent 60%);
  pointer-events: none;
}
.expert__bottom-cta-title {
  font-family: var(--font-display);
  font-size: clamp(1.3rem, 1rem + 1.5vw, 1.8rem);
  font-weight: 700;
  color: var(--dark-text);
  line-height: 1.2;
  margin-bottom: 8px;
}
.expert__bottom-cta-desc {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 400;
  color: var(--dark-text-secondary);
  line-height: 1.6;
  max-width: 480px;
  margin: 0 auto 24px;
}
.expert__bottom-cta-actions {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
  position: relative;
}
.expert__bottom-cta-actions .btn-accent svg,
.expert__bottom-cta-actions .btn-ghost-dark svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
}
.expert__bottom-cta-footnote {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 400;
  color: var(--dark-text-muted);
  position: relative;
}

@media (max-width: 767px) {
  .expert__bottom-cta-actions {
    flex-direction: column;
  }
  .expert__bottom-cta-actions .btn-accent,
  .expert__bottom-cta-actions .btn-ghost-dark {
    width: 100%;
    justify-content: center;
    min-height: 48px;
  }
}

/* ── 7. Sidebar urgency pulse ── */
.sidebar-urgency {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 14px 16px;
  background: var(--dark-bg);
  border-radius: 10px;
  border: 1px solid var(--dark-border);
  margin-top: var(--space-2);
}
.sidebar-urgency .pulse-dot {
  margin-top: 4px;
}
.sidebar-urgency__text {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 400;
  color: var(--dark-text-muted);
  line-height: 1.5;
  margin: 0;
}
.sidebar-urgency__text strong {
  color: var(--dark-text);
  font-weight: 600;
}
.sidebar-urgency__phone {
  color: var(--accent-light);
  font-weight: 700;
  text-decoration: none;
  transition: text-decoration 0.2s ease;
}
.sidebar-urgency__phone:hover {
  text-decoration: underline;
}

/* ── 8. Expert case study (inline, below grid) ── */
.expert__case-study {
  margin-top: var(--space-6);
  padding-top: var(--space-5);
  border-top: 1px solid var(--border);
}
.expert__case-study .cases__eyebrow {
  display: block;
  margin-bottom: var(--space-1);
}
.expert__case-study-heading {
  font-family: var(--font-display);
  font-size: clamp(1.3rem, 1rem + 1.5vw, 1.8rem);
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.2;
  margin-bottom: var(--space-4);
}

/* ============================================================
   RELATED — Powiązane podkategorie (3-kolumnowy grid kart)
   ============================================================ */

.related {
  padding: var(--space-10) 0;
  background: var(--bg-secondary);
}

/* ── Header ── */
.related__header {
  text-align: center;
  margin-bottom: var(--space-5);
}
.related__eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--space-1);
}
.related__headline {
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 1.1rem + 1.5vw, 2rem);
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.15;
}

/* ── Grid ── */
.related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

/* ── Card (entire card is a link) ── */
.related__card {
  display: flex;
  flex-direction: column;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 28px 24px;
  text-decoration: none;
  color: inherit;
  position: relative;
  transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1),
              box-shadow 0.35s ease,
              border-color 0.35s ease;
}
.related__card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: var(--accent-border-solid);
}
.related__card:hover .related__card-arrow {
  transform: translateX(4px);
  color: var(--accent);
}
.related__card:hover .related__card-icon {
  border-color: var(--accent-light);
  box-shadow: 0 0 0 3px rgba(46,107,71,0.08);
}

/* ── Icon ── */
.related__card-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 10px;
  background: var(--accent-bg-solid);
  border: 1px solid var(--accent-border-solid);
  margin-bottom: 16px;
  transition: border-color 0.35s ease, box-shadow 0.35s ease;
}
.related__card-icon svg {
  width: 22px;
  height: 22px;
  stroke: var(--accent);
}

/* ── Content ── */
.related__card-content {
  flex: 1;
}
.related__card-title {
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.3;
  margin-bottom: 8px;
}
.related__card-desc {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 400;
  color: var(--text-tertiary);
  line-height: 1.6;
  margin-bottom: 14px;
}
.related__card-badge {
  display: inline-block;
  background: var(--accent-bg);
  border: 1px solid var(--accent-border);
  padding: 3px 10px;
  border-radius: 4px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  color: var(--accent);
}

/* ── Arrow ── */
.related__card-arrow {
  position: absolute;
  top: 28px;
  right: 24px;
  color: var(--text-muted);
  transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1), color 0.3s ease;
}
.related__card-arrow svg {
  width: 18px;
  height: 18px;
}

/* ── Responsive: Tablet ── */
@media (max-width: 960px) {
  .related__grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .related__card {
    flex-direction: row;
    align-items: center;
    gap: 16px;
    padding: 20px;
  }
  .related__card-icon {
    margin-bottom: 0;
    flex-shrink: 0;
  }
  .related__card-desc {
    display: none;
  }
  .related__card-arrow {
    position: static;
    flex-shrink: 0;
    margin-left: auto;
  }
}

/* ── Responsive: Mobile ── */
@media (max-width: 767px) {
  .related {
    padding: var(--space-7) 0;
  }
  .related__card {
    padding: 16px;
  }
  .related__card-icon {
    width: 38px;
    height: 38px;
  }
  .related__card-icon svg {
    width: 18px;
    height: 18px;
  }
  .related__card-title {
    font-size: 14px;
  }
  .related__card-badge {
    display: none;
  }
}

/* ============================================================
   A24-HERO — Adwokat 24 Hero Section (Split Layout + Live Card)
   ============================================================ */

/*
  @property declarations for CSS Houdini animated angles.
  These allow smooth interpolation of angle values in conic-gradient,
  which standard CSS cannot transition. Falls back gracefully —
  browsers without @property support get a static border instead.
*/
@property --a24-card-angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}
@property --a24-scan-angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}

/* ── Section — dark emergency atmosphere ── */
.a24-hero {
  position: relative;
  background: #0A0A0A;
  min-height: 90vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(96px, 12vw, 200px) 0 clamp(48px, 5vw, 72px);
  overflow: hidden;
}
/* Gradient fade at bottom of hero into next section */
.a24-hero::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 120px;
  background: linear-gradient(to bottom, transparent, #0A0A0A);
  pointer-events: none;
  z-index: 1;
}

/* Layered emergency atmosphere:
   - Deep red vignette at edges (danger framing)
   - Subtle green accent where the card lives (draws eye right)
   - Dark bottom gradient for grounding */
.a24-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 120% 80% at 0% 0%, rgba(180,40,40,0.08) 0%, transparent 50%),
    radial-gradient(ellipse 80% 100% at 100% 100%, rgba(180,40,40,0.06) 0%, transparent 50%),
    radial-gradient(ellipse 50% 60% at 80% 40%, rgba(46,107,71,0.06) 0%, transparent 50%),
    radial-gradient(ellipse 60% 40% at 50% 100%, rgba(0,0,0,0.5) 0%, transparent 70%);
  pointer-events: none;
  z-index: 1;
}

/* Slow pulsing red ambient glow — reinforces urgency without overwhelming */
.a24-hero__bg-pulse {
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 100% 80% at 50% 50%, rgba(200,50,50,0.04) 0%, transparent 70%);
  animation: a24BgPulse 4s ease-in-out infinite alternate;
  pointer-events: none;
  z-index: 0;
}
@keyframes a24BgPulse {
  0%   { opacity: 0.3; }
  100% { opacity: 1; }
}

/* Subtle grid pattern overlay — adds tactical/operational feel */
.a24-hero__bg-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.015) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.015) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
  z-index: 1;
}

/* Emergency top line — red-to-green gradient, pulsing */
.a24-hero__topline {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent, #DC3232, var(--accent-light), #DC3232, transparent);
  opacity: 0.7;
  animation: a24ToplinePulse 3s ease-in-out infinite alternate;
  z-index: 2;
}
@keyframes a24ToplinePulse {
  0%   { opacity: 0.4; }
  100% { opacity: 0.8; }
}

/* ── Grid ── */
/* Container needs to sit above background effects */
.a24-hero > .container {
  position: relative;
  z-index: 2;
}

.a24-hero__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 5vw, 80px);
  align-items: center;
}

/* ── Entrance Animations ── */
.a24-anim {
  opacity: 0;
  transform: translateY(24px);
  animation: a24FadeInUp 0.65s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.a24-anim--1  { animation-delay: 0.05s; }
.a24-anim--2  { animation-delay: 0.15s; }
.a24-anim--3  { animation-delay: 0.25s; }
.a24-anim--4  { animation-delay: 0.35s; }
.a24-anim--4b { animation-delay: 0.4s; }
.a24-anim--5  { animation-delay: 0.5s; }
.a24-anim--6  { animation-delay: 0.6s; }
.a24-anim--card { animation-delay: 0.2s; }

@keyframes a24FadeInUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Left Column: Text ── */
.a24-hero__content {
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* Eyebrow */
.a24-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: var(--space-3);
}
.a24-hero__dot {
  width: 10px;
  height: 10px;
  background: #DC3232;
  border-radius: 50%;
  position: relative;
  flex-shrink: 0;
}
.a24-hero__dot::after {
  content: '';
  position: absolute;
  inset: -5px;
  border-radius: 50%;
  background: #DC3232;
  opacity: 0;
  animation: a24DotPulse 2s ease-in-out infinite;
}
@keyframes a24DotPulse {
  0%   { transform: scale(0.8); opacity: 0.6; }
  50%  { transform: scale(2); opacity: 0; }
  100% { transform: scale(2); opacity: 0; }
}
.a24-hero__eyebrow-text {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: #FF6B6B;
}

/* H1 */
.a24-hero__heading {
  font-family: var(--font-display);
  font-size: clamp(2rem, 1.4rem + 3vw, 3.25rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--text-inverse);
  margin-bottom: var(--space-2);
}
.a24-hero__heading em {
  font-family: var(--font-display);
  font-style: normal;
  font-weight: 500;
  color: #FF6B6B;
}

/* Lead */
.a24-hero__lead {
  font-family: var(--font-body);
  font-size: clamp(1rem, 0.9rem + 0.5vw, 1.15rem);
  font-weight: 400;
  line-height: 1.65;
  color: var(--dark-text-secondary);
  max-width: 500px;
  margin-bottom: var(--space-4);
}

/* Pill cloud */
.a24-hero__pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: var(--space-3);
}
.a24-hero__pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 16px;
  border-radius: 100px;
  background: rgba(220,50,50,0.08);
  border: 1px solid rgba(220,50,50,0.2);
  font-size: 12px;
  font-weight: 600;
  color: #FF8A8A;
  text-decoration: none;
  transition: all 0.3s ease;
}
.a24-hero__pill:hover {
  background: #DC3232;
  color: #fff;
  border-color: #DC3232;
  transform: translateY(-1px);
}
.a24-hero__pill:focus-visible {
  outline: 2px solid #FF6B6B;
  outline-offset: 2px;
}

/* Urgent badge — red pulsing attention-grabber */
.a24-hero__urgent-badge {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  gap: 8px;
  padding: 5px 14px;
  border-radius: 100px;
  background: rgba(220,50,50,0.12);
  border: 1px solid rgba(220,50,50,0.3);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #FF6B6B;
  margin-bottom: var(--space-1);
  animation: a24FadeInUp 0.65s cubic-bezier(0.16, 1, 0.3, 1) 0.05s forwards, a24UrgentPulse 2.5s ease-in-out infinite 1s;
  opacity: 0;
}
.a24-hero__urgent-dot {
  width: 8px;
  height: 8px;
  background: #DC3232;
  border-radius: 50%;
  flex-shrink: 0;
  animation: a24UrgentDotBlink 1.5s ease-in-out infinite;
}
@keyframes a24UrgentDotBlink {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.3; }
}
@keyframes a24UrgentPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(220,50,50,0); }
  50% { box-shadow: 0 0 12px 2px rgba(220,50,50,0.15); }
}

/* Hot pills — brighter red, blinking dot, glow border */
.a24-hero__pill--hot {
  background: rgba(220,50,50,0.15);
  border-color: rgba(220,50,50,0.45);
  color: #FF6B6B;
  font-weight: 700;
  box-shadow: 0 0 8px rgba(220,50,50,0.12), inset 0 0 8px rgba(220,50,50,0.06);
  animation: a24PillGlow 2.5s ease-in-out infinite alternate;
}
.a24-hero__pill--hot:hover {
  background: #DC3232;
  color: #fff;
  border-color: #DC3232;
  box-shadow: 0 0 16px rgba(220,50,50,0.4);
  animation: none;
}
.a24-hero__pill-dot {
  width: 6px;
  height: 6px;
  background: #DC3232;
  border-radius: 50%;
  flex-shrink: 0;
  animation: a24UrgentDotBlink 1.5s ease-in-out infinite;
}
.a24-hero__pill--hot:hover .a24-hero__pill-dot {
  background: #fff;
  animation: none;
}
@keyframes a24PillGlow {
  0%   { box-shadow: 0 0 6px rgba(220,50,50,0.08), inset 0 0 6px rgba(220,50,50,0.04); }
  100% { box-shadow: 0 0 14px rgba(220,50,50,0.2), inset 0 0 10px rgba(220,50,50,0.08); }
}

/* Testimonial slider */
.a24-hero__testimonials {
  margin-bottom: var(--space-3);
}
.a24-testimonial {
  position: relative;
  overflow: hidden;
  min-height: 52px;
  padding-left: var(--space-2);
  border-left: 2px solid rgba(220,50,50,0.3);
}
.a24-testimonial__track {
  position: relative;
}
.a24-testimonial__slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 0.4s ease, transform 0.4s ease;
  pointer-events: none;
}
.a24-testimonial__slide.is-active {
  position: relative;
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.a24-testimonial__slide p {
  font-family: var(--font-display);
  font-size: clamp(0.95rem, 0.85rem + 0.4vw, 1.1rem);
  font-style: normal;
  font-weight: 400;
  line-height: 1.5;
  color: var(--dark-text-secondary);
  margin-bottom: 4px;
}
.a24-testimonial__slide cite {
  font-family: var(--font-body);
  font-size: 11px;
  font-style: normal;
  font-weight: 600;
  color: var(--dark-text-muted);
  letter-spacing: 0.5px;
}
.a24-testimonial__dots {
  display: flex;
  gap: 8px;
  margin-top: 12px;
}
.a24-testimonial__dot {
  width: 6px;
  height: 6px;
  border-radius: 100px;
  background: var(--dark-border);
  border: none;
  padding: 0;
  cursor: pointer;
  transition: all 0.35s cubic-bezier(0.16, 1, 0.3, 1);
}
.a24-testimonial__dot.is-active {
  background: #FF6B6B;
  width: 24px;
}
.a24-testimonial__dot:hover {
  background: #FF6B6B;
}
.a24-testimonial__dot:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
}

/* Social proof strip */
.a24-hero__proof {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}
.a24-hero__proof-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--dark-text-muted);
}
.a24-hero__proof-item svg {
  width: 14px;
  height: 14px;
  stroke: #FF6B6B;
  fill: none;
  flex-shrink: 0;
}
.a24-hero__proof-sep {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: var(--dark-border);
  flex-shrink: 0;
}

/* Footnote */
.a24-hero__footnote {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 600;
  color: var(--dark-text-muted);
  letter-spacing: 0.3px;
}
.a24-hero__footnote svg {
  color: #FF6B6B;
  flex-shrink: 0;
}

/* ── Right Column: Contact Card ── */
.a24-hero__card-wrap {
  position: relative;
  display: flex;
  justify-content: center;
}

/* Ambient glow behind the card — red emergency variant */
.a24-hero__card-wrap::before {
  content: '';
  position: absolute;
  inset: -20px;
  border-radius: 30px;
  background:
    radial-gradient(ellipse at 30% 20%, rgba(220,50,50,0.08) 0%, transparent 50%),
    radial-gradient(ellipse at 70% 80%, rgba(220,50,50,0.06) 0%, transparent 50%);
  pointer-events: none;
  z-index: 0;
  animation: a24Ambient 5s ease-in-out infinite alternate;
}
@keyframes a24Ambient {
  0%   { opacity: 0.3; transform: scale(0.96); }
  50%  { opacity: 0.7; transform: scale(1.02); }
  100% { opacity: 0.4; transform: scale(0.98); }
}

/* Card wrapper (provides the 3D perspective context) */
.a24-card {
  position: relative;
  border-radius: 20px;
  padding: 1.5px;
  perspective: 1200px;
  width: 100%;
  max-width: 420px;
  z-index: 1;
}

/* Tilt container — applies subtle 3D rotation on hover via JS */
.a24-card__tilt {
  border-radius: 20px;
  position: relative;
  transition: transform 0.1s ease-out;
  will-change: transform;
}

/*
  ROTATING CONIC-GRADIENT BORDER
  The pseudo-element creates a full conic-gradient that covers the element.
  The mask trick works by:
  1. First mask layer: white everywhere (content-box) — this is what's opaque
  2. Second mask layer: white everywhere (no constraint) — this is the full area
  3. XOR composite: shows only the area that's in one but not both = the padding area
  This effectively "cuts out" the interior, leaving only the 1.5px padding as visible border.
  The --a24-card-angle custom property rotates the gradient origin over 8s.
*/
.a24-card__tilt::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 20px;
  padding: 1.5px;
  background: conic-gradient(
    from var(--a24-card-angle, 0deg),
    rgba(220,50,50,0.6),
    rgba(220,50,50,0.05),
    rgba(220,50,50,0.05),
    rgba(220,50,50,0.6),
    rgba(220,50,50,0.05),
    rgba(220,50,50,0.05),
    rgba(220,50,50,0.6)
  );
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  animation: a24BorderSpin 8s linear infinite;
  z-index: 1;
}
@keyframes a24BorderSpin { to { --a24-card-angle: 360deg; } }

/*
  SCANNING LINE
  Same mask technique, but the conic-gradient only has a narrow ~8deg bright wedge.
  Rotates faster (3.5s) with a slight blur for a "radar sweep" effect.
*/
.a24-card__tilt::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 20px;
  padding: 2px;
  background: conic-gradient(
    from var(--a24-scan-angle, 0deg),
    transparent 340deg,
    rgba(220,50,50,0.8) 352deg,
    rgba(220,50,50,0.3) 356deg,
    transparent 360deg
  );
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  animation: a24ScanSpin 3.5s linear infinite;
  filter: blur(3px);
  z-index: 2;
}
@keyframes a24ScanSpin { to { --a24-scan-angle: 360deg; } }

/* Card interior — dark with subtle red tint */
.a24-card__inner {
  background: linear-gradient(170deg,
    rgba(60,20,20,0.5) 0%,
    rgba(13,13,13,0.97) 40%,
    rgba(13,13,13,0.97) 60%,
    rgba(50,15,15,0.35) 100%
  );
  border-radius: 19px;
  padding: clamp(32px, 4vw, 48px) clamp(24px, 3vw, 40px);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 8px;
  position: relative;
  overflow: hidden;
  z-index: 3;
}

/* Noise overlay for texture */
.a24-card__inner::before {
  content: '';
  position: absolute;
  inset: 0;
  opacity: 0.03;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 128px 128px;
  pointer-events: none;
  mix-blend-mode: overlay;
}

/* Status badge — red urgent */
.a24-card__status {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px 6px 12px;
  background: rgba(220,50,50,0.12);
  border: 1px solid rgba(220,50,50,0.3);
  border-radius: 100px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #FF6B6B;
  margin-bottom: 12px;
  position: relative;
  z-index: 2;
}
.a24-card__status-dot {
  width: 8px;
  height: 8px;
  background: #DC3232;
  border-radius: 50%;
  position: relative;
  flex-shrink: 0;
}
.a24-card__status-dot::after {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  background: #DC3232;
  opacity: 0;
  animation: a24DotPulse 2s ease-in-out infinite;
}

/* Phone number */
.a24-card__phone {
  font-family: var(--font-body);
  font-size: clamp(1.6rem, 1.2rem + 2vw, 1.75rem);
  font-weight: 700;
  color: var(--emergency-text);
  text-decoration: none;
  letter-spacing: 0.04em;
  line-height: 1.1;
  padding: 4px 0;
  transition: all 0.3s ease;
  position: relative;
  z-index: 2;
}
.a24-card__phone:hover {
  color: #FF6B6B;
  text-shadow: 0 0 30px rgba(220,50,50,0.35);
}
.a24-card__phone:focus-visible {
  outline: 2px solid #FF6B6B;
  outline-offset: 6px;
  border-radius: 4px;
}
.a24-card__phone::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 10%;
  right: 10%;
  height: 1px;
  background: #DC3232;
  opacity: 0.3;
  filter: blur(2px);
  transition: all 0.3s ease;
}
.a24-card__phone:hover::after {
  opacity: 0.7;
  left: 0;
  right: 0;
  filter: blur(4px);
}

/* Label */
.a24-card__label {
  font-size: 12px;
  font-weight: 600;
  color: var(--dark-text-muted);
  letter-spacing: 0.5px;
  margin-bottom: 12px;
  position: relative;
  z-index: 2;
}

/* Divider */
.a24-card__divider {
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--dark-border) 20%, var(--dark-border) 80%, transparent 100%);
  margin: 8px 0;
  position: relative;
  z-index: 2;
}

/* Messaging label */
.a24-card__msg-label {
  font-size: 13px;
  color: var(--dark-text-muted);
  margin-top: 8px;
  margin-bottom: 4px;
  position: relative;
  z-index: 2;
}

/* Channel buttons */
.a24-card__channels {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 4px;
  position: relative;
  z-index: 2;
  width: 100%;
}
.a24-card__channel {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  flex: 1;
  padding: 10px 16px;
  border-radius: 10px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  color: var(--dark-text-secondary);
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.3s ease;
}
.a24-card__channel:hover {
  background: rgba(220,50,50,0.1);
  border-color: rgba(220,50,50,0.3);
  color: #FF6B6B;
  transform: translateY(-1px);
}
.a24-card__channel:focus-visible {
  outline: 2px solid #FF6B6B;
  outline-offset: 2px;
}
.a24-card__channel svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
  flex-shrink: 0;
}

/* SMS fallback */
.a24-card__sms {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 500;
  color: var(--dark-text-muted);
  text-decoration: none;
  margin-top: 12px;
  padding: 4px 0;
  position: relative;
  z-index: 2;
  transition: color 0.3s ease;
}
.a24-card__sms:hover {
  color: #FF6B6B;
}
.a24-card__sms:focus-visible {
  outline: 2px solid #FF6B6B;
  outline-offset: 4px;
  border-radius: 2px;
}
.a24-card__sms svg {
  color: currentColor;
  stroke: currentColor;
}

/* ── A24-HERO Responsive ── */

/* Tablet: single column */
@media (max-width: 960px) {
  .a24-hero__grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .a24-hero__content {
    text-align: center;
    align-items: center;
  }
  .a24-hero__urgent-badge {
    align-self: center;
  }
  .a24-hero__eyebrow {
    justify-content: center;
  }
  .a24-hero__lead {
    max-width: 100%;
  }
  .a24-hero__pills {
    justify-content: center;
  }
  .a24-hero__proof {
    justify-content: center;
  }
  .a24-hero__footnote {
    justify-content: center;
  }
  .a24-hero__card-wrap {
    justify-content: center;
  }
  .a24-card {
    max-width: 400px;
  }
}

/* Mobile */
@media (max-width: 600px) {
  .a24-hero {
    padding-top: clamp(80px, 10vw, 120px);
    padding-bottom: 40px;
    min-height: auto;
  }
  .a24-hero__heading {
    font-size: clamp(1.75rem, 1.2rem + 3vw, 2.5rem);
  }
  .a24-hero__pills {
    gap: 5px;
  }
  .a24-hero__pill {
    padding: 5px 12px;
    font-size: 11px;
  }
  .a24-card {
    max-width: 360px;
  }
  .a24-card__inner {
    padding: 28px 20px;
  }
  .a24-hero__card-wrap::before {
    inset: -20px;
    border-radius: 40px;
  }
  .a24-card__channels {
    flex-direction: column;
    gap: 8px;
  }
  .a24-card__channel {
    width: 100%;
    min-height: 48px;
    padding: 14px 20px;
  }
}

/* ── Reduced Motion ── */
@media (prefers-reduced-motion: reduce) {
  .a24-anim,
  .a24-hero__urgent-badge {
    opacity: 1;
    transform: none;
    animation: none;
  }
  .a24-hero__dot::after,
  .a24-card__status-dot::after,
  .a24-hero__urgent-dot,
  .a24-hero__pill-dot,
  .a24-hero__pill--hot,
  .a24-hero__bg-pulse,
  .a24-hero__topline {
    animation: none;
  }
  .a24-card__tilt::after {
    animation: none;
    opacity: 0.5;
  }
  .a24-card__tilt::before {
    animation: none;
    opacity: 0;
  }
  .a24-hero__card-wrap::before {
    animation: none;
    opacity: 0.5;
  }
}

/* ── Forced Colors (High Contrast) ── */
@media (forced-colors: active) {
  .a24-card__tilt::after,
  .a24-card__tilt::before {
    display: none;
  }
  .a24-card__inner {
    border: 2px solid ButtonText;
  }
  .a24-hero__pill {
    border: 1px solid ButtonText;
  }
  .a24-card__channel {
    border: 1px solid ButtonText;
  }
}

/* ============================================================
   A24-TIMELINE — "Jak to działa" Interactive Timeline
   ============================================================ */

/* ── Section ── */
.a24-timeline {
  background: linear-gradient(to bottom, #0F0F0F 0%, #0A0A0A 100%);
  padding: clamp(72px, 8vw, 128px) 0;
  position: relative;
  overflow: hidden;
}
.a24-timeline::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.012) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.012) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
  z-index: 0;
}
.a24-timeline > .container {
  position: relative;
  z-index: 1;
}

/* ── Header ── */
.a24-timeline__header {
  text-align: center;
  margin-bottom: clamp(48px, 6vw, 72px);
}
.a24-timeline__eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2.5px;
  color: #FF6B6B;
  margin-bottom: 12px;
}
.a24-timeline__heading {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 1.2rem + 1.5vw, 2.4rem);
  font-weight: 700;
  color: var(--emergency-text);
  line-height: 1.2;
  margin-bottom: 12px;
}
.a24-timeline__lead {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--dark-text-muted);
  max-width: 480px;
  margin: 0 auto;
  line-height: 1.6;
}

/* ── Desktop: Horizontal Timeline ── */
.a24-timeline__steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(20px, 3vw, 40px);
  position: relative;
  list-style: none;
}

/* Connecting line — spans between node centers */
.a24-timeline__steps::before {
  content: '';
  position: absolute;
  top: 28px; /* vertical center of 56px node */
  left: calc(100% / 6);
  right: calc(100% / 6);
  height: 2px;
  background: linear-gradient(90deg, rgba(220,50,50,0.1), rgba(220,50,50,0.3), rgba(220,50,50,0.1));
  z-index: 0;
}

/* ── Step ── */
.a24-timeline__step {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
}

/* ── Node — compact icon dot on the timeline line ── */
.a24-timeline__node {
  margin-bottom: var(--space-2);
  position: relative;
  z-index: 2;
}
.a24-timeline__node-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: rgba(220,50,50,0.1);
  border: 1.5px solid rgba(220,50,50,0.3);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.a24-timeline__node-icon svg {
  width: 24px;
  height: 24px;
  stroke: #FF6B6B;
  fill: none;
}
.a24-timeline__step:hover .a24-timeline__node-icon {
  background: #DC3232;
  border-color: #DC3232;
  box-shadow: 0 0 20px rgba(220,50,50,0.3);
  transform: scale(1.1);
}
.a24-timeline__step:hover .a24-timeline__node-icon svg {
  stroke: #fff;
}

/* ── Card ── */
.a24-timeline__card {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
  padding: clamp(20px, 2.5vw, 28px);
  width: 100%;
  flex: 1;
  position: relative;
  overflow: hidden;
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
/* Watermark — large ghost number in card background */
.a24-timeline__watermark {
  position: absolute;
  top: -8px;
  right: 12px;
  font-family: var(--font-display);
  font-size: 72px;
  font-weight: 700;
  color: rgba(220,50,50,0.06);
  line-height: 1;
  pointer-events: none;
  user-select: none;
  transition: color 0.4s ease;
}
.a24-timeline__step:hover .a24-timeline__watermark {
  color: rgba(220,50,50,0.1);
}

.a24-timeline__step:hover .a24-timeline__card {
  background: rgba(220,50,50,0.04);
  border-color: rgba(220,50,50,0.15);
  transform: translateY(-4px);
  box-shadow: 0 8px 32px rgba(220,50,50,0.08);
}

.a24-timeline__card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 10px;
}

/* Title */
.a24-timeline__title {
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 700;
  color: var(--emergency-text);
  line-height: 1.3;
}

/* Time badge */
.a24-timeline__badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 100px;
  background: rgba(220,50,50,0.1);
  border: 1px solid rgba(220,50,50,0.2);
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.5px;
  color: #FF6B6B;
  white-space: nowrap;
  flex-shrink: 0;
}

/* Description */
.a24-timeline__desc {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 400;
  color: var(--dark-text-muted);
  line-height: 1.65;
  margin-bottom: 12px;
}

/* Detail line */
.a24-timeline__detail {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,0.06);
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  color: var(--dark-text-secondary);
  line-height: 1.5;
}
.a24-timeline__detail svg {
  width: 14px;
  height: 14px;
  stroke: #FF6B6B;
  flex-shrink: 0;
  margin-top: 1px;
}

/* ── CTA ── */
.a24-timeline__cta {
  text-align: center;
  margin-top: clamp(40px, 5vw, 64px);
}
.a24-timeline__cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 32px;
  border-radius: 10px;
  background: linear-gradient(135deg, #DC3232 0%, #a02020 100%);
  color: #fff;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.3px;
  text-decoration: none;
  transition: all 0.3s ease;
  position: relative;
  box-shadow: 0 4px 20px rgba(220,50,50,0.25);
}
.a24-timeline__cta-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(220,50,50,0.35);
}
.a24-timeline__cta-btn:focus-visible {
  outline: 2px solid #FF6B6B;
  outline-offset: 4px;
}
.a24-timeline__cta-btn svg {
  width: 18px;
  height: 18px;
  stroke: #fff;
  fill: none;
  flex-shrink: 0;
}
.a24-timeline__cta-pulse {
  width: 8px;
  height: 8px;
  background: #fff;
  border-radius: 50%;
  flex-shrink: 0;
  animation: a24CtaPulse 2s ease-in-out infinite;
}
@keyframes a24CtaPulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.5; transform: scale(0.7); }
}

/* ── Scroll Reveal ──
   JS adds .a24-tl-hidden on init, then .is-visible on scroll.
   Without JS, content is visible by default (progressive enhancement). */
.a24-tl-hidden {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}
.a24-tl-hidden.is-visible {
  opacity: 1;
  transform: translateY(0);
}
/* Stagger delays for sequential reveal */
.a24-timeline__step:nth-child(2).a24-tl-hidden { transition-delay: 0.12s; }
.a24-timeline__step:nth-child(3).a24-tl-hidden { transition-delay: 0.24s; }
.a24-timeline__cta.a24-tl-hidden { transition-delay: 0.36s; }

/* ── Mobile: Vertical Timeline (< 700px) ── */
@media (max-width: 700px) {
  .a24-timeline__steps {
    grid-template-columns: 1fr;
    gap: 0;
    padding-left: 28px;
  }

  /* Vertical connecting line */
  .a24-timeline__steps::before {
    top: 28px;
    bottom: 28px;
    left: 56px; /* 28px padding + 28px half-node */
    right: auto;
    width: 2px;
    height: auto;
    background: linear-gradient(to bottom, rgba(220,50,50,0.1), rgba(220,50,50,0.3), rgba(220,50,50,0.1));
    transform: translateX(-50%);
  }

  .a24-timeline__step {
    flex-direction: row;
    align-items: flex-start;
    text-align: left;
    gap: var(--space-2);
    padding-bottom: var(--space-4);
  }
  .a24-timeline__step:last-child {
    padding-bottom: 0;
  }

  .a24-timeline__node {
    margin-bottom: 0;
    flex-shrink: 0;
  }

  .a24-timeline__watermark {
    font-size: 56px;
    top: -4px;
    right: 8px;
  }

  .a24-timeline__card-top {
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
  }
}

/* ── Reduced Motion ── */
@media (prefers-reduced-motion: reduce) {
  .a24-tl-reveal,
  .a24-tl-hidden {
    opacity: 1;
    transform: none;
    transition: none;
  }
  .a24-timeline__cta-pulse {
    animation: none;
  }
}

/* ── Forced Colors ── */
@media (forced-colors: active) {
  .a24-timeline__node-icon {
    border: 2px solid ButtonText;
  }
  .a24-timeline__card {
    border: 1px solid ButtonText;
  }
  .a24-timeline__watermark {
    display: none;
  }
  .a24-timeline__steps::before {
    background: ButtonText;
  }
}

/* ============================================================
   REVIEWS — Adwokat 24 Emergency Dark Override
   Scoped to #opinie-a24 so it doesn't affect index.html
   ============================================================ */

#opinie-a24 {
  --reviews-card-bg: rgba(255,255,255,0.03);
  --reviews-card-border: rgba(255,255,255,0.06);
  --reviews-card-shadow: none;
  --reviews-card-shadow-hover: 0 8px 32px rgba(220,50,50,0.08);
  --reviews-star-color: #FF6B6B;
  --reviews-quote-color: var(--dark-text-secondary);
  --reviews-meta-color: var(--dark-text-muted);

  background: #0A0A0A;
  position: relative;
  overflow: hidden;
}

/* Grid overlay */
#opinie-a24::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.012) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.012) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
  z-index: 0;
}
#opinie-a24 > .container {
  position: relative;
  z-index: 1;
}

/* Header */
#opinie-a24 .reviews__eyebrow {
  color: #FF6B6B;
}
#opinie-a24 .reviews__headline {
  color: var(--emergency-text);
}

/* Card hover — red glow */
#opinie-a24 .reviews__card:hover {
  border-color: rgba(220,50,50,0.15);
}

/* Author name */
#opinie-a24 .reviews__author {
  color: var(--dark-text);
}

/* Arrows — dark style */
#opinie-a24 .reviews__arrow {
  background: rgba(255,255,255,0.05);
  border-color: rgba(255,255,255,0.1);
  color: var(--dark-text-muted);
}
#opinie-a24 .reviews__arrow:hover {
  background: rgba(220,50,50,0.1);
  border-color: rgba(220,50,50,0.25);
  color: #FF6B6B;
}
#opinie-a24 .reviews__arrow:focus-visible {
  outline-color: #FF6B6B;
}
#opinie-a24 .reviews__arrow svg {
  stroke: currentColor;
}

/* Dots */
#opinie-a24 .reviews__dot {
  background: rgba(255,255,255,0.15);
}
#opinie-a24 .reviews__dot.is-active {
  background: #DC3232;
}
#opinie-a24 .reviews__dot:hover {
  background: #FF6B6B;
}

/* Google link — red */
#opinie-a24 .reviews__link {
  color: #FF6B6B;
}
#opinie-a24 .reviews__link:hover {
  color: #FF8A8A;
}

/* Tablet: arrow backdrop override */
@media (max-width: 1100px) {
  #opinie-a24 .reviews__arrow {
    background: rgba(10,10,10,0.85);
    backdrop-filter: blur(4px);
  }
}

/* ============================================================
   ECTA — Adwokat 24 Red Emergency Override
   Scoped to #ecta-a24
   ============================================================ */

/* Section background — darker, with red vignette */
#ecta-a24 {
  background: #080808;
}
#ecta-a24::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 100% 80% at 0% 0%, rgba(180,40,40,0.06) 0%, transparent 50%),
    radial-gradient(ellipse 80% 80% at 100% 100%, rgba(180,40,40,0.04) 0%, transparent 50%);
  pointer-events: none;
}
#ecta-a24::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.012) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.012) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
}
#ecta-a24 .ecta__container {
  position: relative;
  z-index: 1;
}

/* Eyebrow dot + text — red */
#ecta-a24 .ecta__dot {
  background: #DC3232;
}
#ecta-a24 .ecta__dot::after {
  background: #DC3232;
}
#ecta-a24 .ecta__eyebrow-text {
  color: #FF6B6B;
}

/* Tags — red pills */
#ecta-a24 .ecta__tag {
  background: rgba(220,50,50,0.08);
  border-color: rgba(220,50,50,0.2);
  color: #FF8A8A;
}
#ecta-a24 .ecta__tag:hover {
  background: #DC3232;
  color: #fff;
  border-color: #DC3232;
}
#ecta-a24 .ecta__tag:focus-visible {
  outline-color: #FF6B6B;
}

/* Card — red rotating border */
#ecta-a24 .ecta__card-tilt::after {
  background: conic-gradient(
    from var(--card-angle, 0deg),
    rgba(220,50,50,0.6),
    rgba(220,50,50,0.05),
    rgba(220,50,50,0.05),
    rgba(220,50,50,0.6),
    rgba(220,50,50,0.05),
    rgba(220,50,50,0.05),
    rgba(220,50,50,0.6)
  );
}

/* Card — red scanning line */
#ecta-a24 .ecta__card-tilt::before {
  background: conic-gradient(
    from var(--scan-angle, 0deg),
    transparent 340deg,
    rgba(220,50,50,0.8) 352deg,
    rgba(220,50,50,0.3) 356deg,
    transparent 360deg
  );
}

/* Card — red ambient glow */
#ecta-a24 .ecta__card::before {
  background:
    radial-gradient(ellipse at 30% 20%, rgba(220,50,50,0.12) 0%, transparent 50%),
    radial-gradient(ellipse at 70% 80%, rgba(220,50,50,0.08) 0%, transparent 50%);
}

/* Card inner — dark with red tint */
#ecta-a24 .ecta__card-inner {
  background: linear-gradient(170deg,
    rgba(60,20,20,0.5) 0%,
    rgba(13,13,13,0.97) 40%,
    rgba(13,13,13,0.97) 60%,
    rgba(50,15,15,0.35) 100%
  );
}

/* Status badge — red */
#ecta-a24 .ecta__card-status {
  background: rgba(220,50,50,0.12);
  border-color: rgba(220,50,50,0.3);
  color: #FF6B6B;
}
#ecta-a24 .ecta__card-status .ecta__dot {
  background: #DC3232;
}
#ecta-a24 .ecta__card-status .ecta__dot::after {
  background: #DC3232;
}

/* Phone hover — red */
#ecta-a24 .ecta__phone:hover {
  color: #FF6B6B;
  text-shadow: 0 0 30px rgba(220,50,50,0.35);
}
#ecta-a24 .ecta__phone::after {
  background: #DC3232;
}
#ecta-a24 .ecta__phone:focus-visible {
  outline-color: #FF6B6B;
}

/* Trust — red star */
#ecta-a24 .ecta__card-trust svg {
  fill: #FF6B6B;
}

/* Channels — red hover */
#ecta-a24 .ecta__channel:hover {
  background: rgba(220,50,50,0.1);
  border-color: rgba(220,50,50,0.3);
  color: #FF6B6B;
}
#ecta-a24 .ecta__channel:focus-visible {
  outline-color: #FF6B6B;
}

/* Encryption note — red icon */
#ecta-a24 .ecta__encryption-note svg {
  fill: #FF6B6B;
}

/* Headline em — red accent */
#ecta-a24 .ecta__headline em {
  font-style: normal;
  color: #FF6B6B;
}

/* Hot tags — brighter, bolder */
#ecta-a24 .ecta__tag--hot {
  background: rgba(220,50,50,0.15);
  border-color: rgba(220,50,50,0.4);
  color: #FF6B6B;
  font-weight: 700;
}
#ecta-a24 .ecta__tag--hot:hover {
  box-shadow: 0 0 12px rgba(220,50,50,0.3);
}

/* Divider — red tint */
#ecta-a24 .ecta__card-divider {
  background: linear-gradient(90deg, transparent 0%, rgba(220,50,50,0.2) 20%, rgba(220,50,50,0.2) 80%, transparent 100%);
}

/* ============================================================
   FAQ — Adwokat 24 Dark Emergency Override
   Scoped to #faq-a24
   ============================================================ */

/* Section */
#faq-a24 {
  background: #0A0A0A;
  position: relative;
}
#faq-a24::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.012) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.012) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
  z-index: 0;
}
#faq-a24 > .container {
  position: relative;
  z-index: 1;
}

/* Header */
#faq-a24 .faq__eyebrow {
  color: #FF6B6B;
}
#faq-a24 .faq__headline {
  color: var(--emergency-text);
}

/* Accordion items — dark borders */
#faq-a24 .faq__item {
  border-color: rgba(255,255,255,0.06);
}
#faq-a24 .faq__item:first-child {
  border-color: rgba(255,255,255,0.06);
}

/* Question button */
#faq-a24 .faq__question {
  color: var(--dark-text);
}
#faq-a24 .faq__question:hover {
  color: #FF6B6B;
}
#faq-a24 .faq__question:focus-visible {
  outline-color: #FF6B6B;
}

/* Icon — red */
#faq-a24 .faq__icon {
  background: rgba(220,50,50,0.08);
  border-color: rgba(220,50,50,0.2);
}
#faq-a24 .faq__icon svg {
  stroke: #FF6B6B;
}
#faq-a24 .faq__question[aria-expanded="true"] .faq__icon {
  background: rgba(220,50,50,0.15);
  border-color: rgba(220,50,50,0.3);
}
#faq-a24 .faq__question[aria-expanded="true"] .faq__icon svg {
  stroke: #FF6B6B;
}

/* Answer text */
#faq-a24 .faq__answer-inner p {
  color: var(--dark-text-secondary);
}
#faq-a24 .faq__answer-inner a {
  color: #FF6B6B;
  text-decoration-color: rgba(220,50,50,0.3);
}
#faq-a24 .faq__answer-inner a:hover {
  text-decoration-color: #FF6B6B;
}

/* Sidebar card — dark elevated */
#faq-a24 .faq__sidebar-card {
  background: rgba(255,255,255,0.03);
  border-color: rgba(255,255,255,0.06);
}
#faq-a24 .faq__sidebar-card:hover {
  box-shadow: 0 8px 32px rgba(220,50,50,0.08);
  border-color: rgba(220,50,50,0.15);
}
#faq-a24 .faq__sidebar-icon {
  background: rgba(220,50,50,0.1);
  border-color: rgba(220,50,50,0.2);
}
#faq-a24 .faq__sidebar-icon svg {
  stroke: #FF6B6B;
}
#faq-a24 .faq__sidebar-headline {
  color: var(--emergency-text);
}
#faq-a24 .faq__sidebar-text {
  color: var(--dark-text-muted);
}
#faq-a24 .faq__sidebar-btn {
  background: #DC3232;
  box-shadow: 0 0 16px rgba(220,50,50,0.25);
}
#faq-a24 .faq__sidebar-btn:hover {
  background: #E04040;
  box-shadow: 0 0 24px rgba(220,50,50,0.35);
}
#faq-a24 .faq__sidebar-meta {
  color: var(--dark-text-muted);
}

/* ============================================================
   RELATED — Adwokat 24 Dark Emergency Override
   Scoped to #related-a24
   ============================================================ */

#related-a24 {
  background: #0A0A0A;
  position: relative;
}
#related-a24::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.012) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.012) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
  z-index: 0;
}
#related-a24 > .container {
  position: relative;
  z-index: 1;
}

/* Header */
#related-a24 .related__eyebrow {
  color: #FF6B6B;
}
#related-a24 .related__headline {
  color: var(--emergency-text);
}

/* Cards — dark */
#related-a24 .related__card {
  background: rgba(255,255,255,0.03);
  border-color: rgba(255,255,255,0.06);
}
#related-a24 .related__card:hover {
  border-color: rgba(220,50,50,0.2);
  box-shadow: 0 8px 32px rgba(220,50,50,0.08);
}

/* Icon */
#related-a24 .related__card-icon {
  background: rgba(220,50,50,0.08);
  border-color: rgba(220,50,50,0.2);
}
#related-a24 .related__card-icon svg {
  stroke: #FF6B6B;
}
#related-a24 .related__card:hover .related__card-icon {
  border-color: #DC3232;
  box-shadow: 0 0 0 3px rgba(220,50,50,0.1);
}

/* Text */
#related-a24 .related__card-title {
  color: var(--dark-text);
}
#related-a24 .related__card-desc {
  color: var(--dark-text-muted);
}

/* Badge */
#related-a24 .related__card-badge {
  background: rgba(220,50,50,0.08);
  border-color: rgba(220,50,50,0.2);
  color: #FF6B6B;
}

/* Arrow */
#related-a24 .related__card-arrow {
  color: var(--dark-text-muted);
}
#related-a24 .related__card:hover .related__card-arrow {
  color: #FF6B6B;
}

/* Focus */
#related-a24 .related__card:focus-visible {
  outline-color: #FF6B6B;
}

/* ============================================================
   FCTA — Adwokat 24 Red Emergency Override
   Scoped to #fcta-a24
   ============================================================ */

#fcta-a24 {
  background: #080808;
  border-top-color: rgba(220,50,50,0.15);
}
#fcta-a24 .fcta__eyebrow {
  color: #FF6B6B;
}
#fcta-a24 .fcta__eyebrow::before {
  background: #DC3232;
}
#fcta-a24 .fcta__headline em {
  font-style: normal;
  color: #FF6B6B;
}
#fcta-a24 .fcta__phone {
  background: #DC3232;
  box-shadow: 0 0 20px rgba(220,50,50,0.25);
}
#fcta-a24 .fcta__phone:hover {
  background: #E04040;
  box-shadow: 0 0 28px rgba(220,50,50,0.35);
}
#fcta-a24 .fcta__channel:hover {
  color: #FF6B6B;
  border-color: rgba(220,50,50,0.3);
}

/* ============================================================
   A24S-HERO — Adwokat 24 Subcategory Split Hero
   Split layout: text left (~55%), full-bleed photo right (~45%).
   Design language: matches a24-hero emergency red palette.
   Prefix: a24s-hero
   ============================================================ */

/* ── Section — dark emergency atmosphere (matches a24-hero) ── */
.a24s-hero {
  --a24s-red: #DC3232;
  --a24s-red-light: #FF6B6B;
  --a24s-red-muted: #FF8A8A;
  --a24s-photo-radius: 24px;
  position: relative;
  background: #0A0A0A;
  min-height: 90vh;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  overflow: hidden;
}

/* Gradient fade at bottom of hero into next section */
.a24s-hero::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 120px;
  background: linear-gradient(to bottom, transparent, #0A0A0A);
  pointer-events: none;
  z-index: 3;
}

/* Layered emergency atmosphere (matches a24-hero::before) */
.a24s-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 120% 80% at 0% 0%, rgba(180,40,40,0.08) 0%, transparent 50%),
    radial-gradient(ellipse 80% 100% at 100% 100%, rgba(180,40,40,0.06) 0%, transparent 50%),
    radial-gradient(ellipse 60% 40% at 50% 100%, rgba(0,0,0,0.5) 0%, transparent 70%);
  pointer-events: none;
  z-index: 1;
}

/* Emergency top line — red-to-green gradient, pulsing (matches a24-hero__topline) */
.a24s-hero__topline {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent, #DC3232, var(--accent-light), #DC3232, transparent);
  opacity: 0.7;
  animation: a24ToplinePulse 3s ease-in-out infinite alternate;
  z-index: 5;
}

/* Slow pulsing red ambient glow (matches a24-hero__bg-pulse) */
.a24s-hero__bg-pulse {
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 100% 80% at 50% 50%, rgba(200,50,50,0.04) 0%, transparent 70%);
  animation: a24BgPulse 4s ease-in-out infinite alternate;
  pointer-events: none;
  z-index: 0;
}

/* Subtle grid pattern overlay (matches a24-hero__bg-grid) */
.a24s-hero__bg-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.015) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.015) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
  z-index: 1;
}

/* Container needs to sit above background effects and fill width */
.a24s-hero > .container {
  position: relative;
  z-index: 2;
  width: 100%;
  padding-top: 180px;
  padding-bottom: clamp(48px, 6vw, 80px);
}

/*
  FULL-BLEED GRID TECHNIQUE:
  55/45 split. Photo column breaks out of the container to the right
  viewport edge via negative margin on the photo-frame.
*/
.a24s-hero__grid {
  display: grid;
  grid-template-columns: 55fr 45fr;
  gap: clamp(40px, 5vw, 80px);
  align-items: stretch;
  min-height: clamp(400px, 50vh, 600px);
}

/* ── Left Column: Text (matches a24-hero__content structure) ── */
.a24s-hero__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0;
}

/* Entrance animations — keyframe based like a24-hero */
.a24s-anim {
  opacity: 0;
  transform: translateY(24px);
  animation: a24FadeInUp 0.65s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.a24s-anim--1  { animation-delay: 0.05s; }
.a24s-anim--2  { animation-delay: 0.15s; }
.a24s-anim--3  { animation-delay: 0.25s; }
.a24s-anim--4  { animation-delay: 0.35s; }
.a24s-anim--5  { animation-delay: 0.45s; }
.a24s-anim--6  { animation-delay: 0.55s; }
.a24s-anim--4b { animation-delay: 0.40s; }
.a24s-anim--5  { animation-delay: 0.45s; }
.a24s-anim--6  { animation-delay: 0.55s; }
.a24s-anim--7  { animation-delay: 0.65s; }
.a24s-anim--8  { animation-delay: 0.75s; }
.a24s-anim--9  { animation-delay: 0.85s; }
.a24s-anim--10 { animation-delay: 1.0s; }
.a24s-anim--photo { animation-delay: 0.2s; }

/* Breadcrumb */
.a24s-hero__breadcrumb {
  margin-bottom: var(--space-2);
}
.a24s-hero__breadcrumb ol {
  display: flex;
  align-items: center;
  gap: 0;
  flex-wrap: wrap;
}
.a24s-hero__breadcrumb li {
  display: flex;
  align-items: center;
  font-size: 12px;
  font-weight: 500;
  color: var(--dark-text-muted);
}
.a24s-hero__breadcrumb li + li::before {
  content: '/';
  margin: 0 8px;
  color: var(--dark-border);
}
.a24s-hero__breadcrumb a {
  color: var(--dark-text-muted);
  text-decoration: none;
  transition: color 0.2s ease;
}
.a24s-hero__breadcrumb a:hover {
  color: #FF6B6B;
}
.a24s-hero__breadcrumb li[aria-current="page"] {
  color: var(--dark-text-secondary);
}

/* Urgent badge (matches a24-hero__urgent-badge) */
.a24s-hero__urgent-badge {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  gap: 8px;
  padding: 5px 14px;
  border-radius: 100px;
  background: rgba(220,50,50,0.12);
  border: 1px solid rgba(220,50,50,0.3);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #FF6B6B;
  margin-bottom: var(--space-1);
  animation: a24FadeInUp 0.65s cubic-bezier(0.16, 1, 0.3, 1) 0.15s forwards, a24UrgentPulse 2.5s ease-in-out infinite 1s;
  opacity: 0;
}
.a24s-hero__urgent-dot {
  width: 8px;
  height: 8px;
  background: #DC3232;
  border-radius: 50%;
  flex-shrink: 0;
  animation: a24UrgentDotBlink 1.5s ease-in-out infinite;
}

/* Eyebrow — kept for backwards compat, hidden when urgent-badge is used */
.a24s-hero__eyebrow {
  display: none;
}

/* Heading (matches a24-hero__heading) */
.a24s-hero__heading {
  font-family: var(--font-display);
  font-size: clamp(2rem, 1.4rem + 3vw, 3.25rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--text-inverse);
  margin-bottom: var(--space-2);
}
.a24s-hero__heading em {
  font-family: var(--font-display);
  font-style: normal;
  font-weight: 500;
  color: #FF6B6B;
}

/* Lead text */
.a24s-hero__lead {
  font-family: var(--font-body);
  font-size: clamp(1rem, 0.9rem + 0.5vw, 1.15rem);
  font-weight: 400;
  line-height: 1.65;
  color: var(--dark-text-secondary);
  max-width: 500px;
  margin-bottom: var(--space-3);
}

/* Phone number — large, prominent, Cormorant Garamond */
.a24s-hero__phone {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  text-decoration: none;
  margin-bottom: var(--space-1);
  transition: transform 0.3s ease;
}
.a24s-hero__phone:hover {
  transform: translateY(-2px);
}
.a24s-hero__phone:focus-visible {
  outline: 2px solid #FF6B6B;
  outline-offset: 6px;
  border-radius: 4px;
}
.a24s-hero__phone-number {
  font-family: var(--font-body);
  font-size: clamp(1.6rem, 1.2rem + 2vw, 1.75rem);
  font-weight: 700;
  color: var(--emergency-text);
  letter-spacing: 0.04em;
  line-height: 1.1;
}
.a24s-hero__phone-number {
  position: relative;
}
.a24s-hero__phone-number::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 10%;
  right: 10%;
  height: 2px;
  background: #DC3232;
  opacity: 0;
  filter: blur(2px);
  transition: all 0.3s ease;
}
.a24s-hero__phone:hover .a24s-hero__phone-number {
  color: #FF6B6B;
  text-shadow: 0 0 30px rgba(220,50,50,0.35);
}
.a24s-hero__phone:hover .a24s-hero__phone-number::after {
  opacity: 0.7;
  left: 0;
  right: 0;
  filter: blur(4px);
}

/* Availability label (matches a24-hero__footnote) */
.a24s-hero__avail {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--dark-text-muted);
  letter-spacing: 0.3px;
  margin-bottom: var(--space-3);
}
.a24s-hero__avail svg {
  color: #FF6B6B;
  flex-shrink: 0;
}
.a24s-hero__avail-dot {
  width: 8px;
  height: 8px;
  background: #DC3232;
  border-radius: 50%;
  flex-shrink: 0;
  animation: a24UrgentDotBlink 1.5s ease-in-out infinite;
}

/* Contact channels (card-style, matches a24-card__channels) */
.a24s-hero__channels {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: var(--space-3);
}
.a24s-hero__channel {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  flex: 1;
  max-width: 160px;
  padding: 10px 16px;
  border-radius: 10px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  color: var(--dark-text-secondary);
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.3s ease;
}
.a24s-hero__channel svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
  flex-shrink: 0;
}
.a24s-hero__channel:hover {
  background: rgba(220,50,50,0.1);
  border-color: rgba(220,50,50,0.3);
  color: #FF6B6B;
  transform: translateY(-1px);
}
.a24s-hero__channel:focus-visible {
  outline: 2px solid #FF6B6B;
  outline-offset: 2px;
}

/* Trust / proof strip (matches a24-hero__proof) */
.a24s-hero__trust {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
}
.a24s-hero__trust-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--dark-text-muted);
}
.a24s-hero__trust-item svg {
  width: 14px;
  height: 14px;
  stroke: #FF6B6B;
  fill: none;
  flex-shrink: 0;
}
.a24s-hero__trust-sep {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: var(--dark-border);
  flex-shrink: 0;
}

/* ── Right column: photo with full-bleed ── */
.a24s-hero__photo {
  position: relative;
  align-self: stretch;
}

/*
  Photo frame: fills the grid cell with animated border.
*/
.a24s-hero__photo-frame {
  position: relative;
  height: 100%;
  min-height: clamp(400px, 50vh, 600px);
  border-radius: var(--a24s-photo-radius);
  overflow: hidden;
  background: linear-gradient(135deg, #2a1515, #0d0a0a);
  padding: 1.5px;
}

/* Rotating conic-gradient border (matches a24-card) */
@property --a24s-photo-angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}
.a24s-hero__photo-frame::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--a24s-photo-radius);
  padding: 1.5px;
  background: conic-gradient(
    from var(--a24s-photo-angle, 0deg),
    rgba(220,50,50,0.4),
    rgba(220,50,50,0.03),
    rgba(220,50,50,0.03),
    rgba(220,50,50,0.4),
    rgba(220,50,50,0.03),
    rgba(220,50,50,0.03),
    rgba(220,50,50,0.4)
  );
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  animation: a24sPhotoBorderSpin 10s linear infinite;
  z-index: 3;
  pointer-events: none;
}
@keyframes a24sPhotoBorderSpin { to { --a24s-photo-angle: 360deg; } }

.a24s-hero__photo-frame img {
  display: block;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

/*
  GRADIENT OVERLAY:
  Left-to-right dark gradient ensures text readability at the column boundary.
  Matches the atmospheric feel of a24-hero.
*/
.a24s-hero__photo-frame::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, rgba(10,10,10,0.75), transparent 60%);
  z-index: 1;
  pointer-events: none;
}

/* Photo entrance — slides in from right */
.a24s-hero__photo.a24s-anim {
  transform: translateX(40px);
}

/* Scroll indicator */
.a24s-hero__scroll {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding-top: var(--space-6, 32px);
  padding-bottom: var(--space-4, 16px);
  text-decoration: none;
  cursor: pointer;
}
.a24s-hero__scroll:hover .a24s-hero__scroll-text {
  color: rgba(255,255,255,0.55);
}
.a24s-hero__scroll:hover .a24s-hero__scroll-chevron {
  color: rgba(220,50,50,0.8);
}
.a24s-hero__scroll-text {
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.35);
}
.a24s-hero__scroll-line {
  width: 1px;
  height: 32px;
  background: linear-gradient(to bottom, rgba(220,50,50,0.4), transparent);
  animation: a24sScrollPulse 2.5s ease-in-out infinite;
}
.a24s-hero__scroll-chevron {
  color: rgba(220,50,50,0.5);
  animation: a24sChevronBounce 2.5s ease-in-out infinite;
}
@keyframes a24sScrollPulse {
  0%, 100% { opacity: 0.3; transform: scaleY(0.7); }
  50% { opacity: 0.8; transform: scaleY(1); }
}
@keyframes a24sChevronBounce {
  0%, 100% { opacity: 0.4; transform: translateY(0); }
  50% { opacity: 0.9; transform: translateY(4px); }
}

/* ── Responsive: tablet ── */
@media (max-width: 960px) {
  .a24s-hero {
    min-height: auto;
  }

  .a24s-hero > .container {
    padding-top: 40px;
  }

  .a24s-hero__grid {
    grid-template-columns: 1fr;
    gap: 0;
    min-height: auto;
  }

  .a24s-hero__grid {
    gap: var(--space-4);
  }

  .a24s-hero__photo-frame {
    min-height: 0;
    height: auto;
    aspect-ratio: 1 / 1;
    border-radius: 16px;
  }

  /* Mobile gradient: bottom-up so text beneath stays readable */
  .a24s-hero__photo-frame::before {
    background: linear-gradient(to top, rgba(10,10,10,0.8), transparent 70%);
  }

  .a24s-hero__content {
    padding: var(--space-4) 0 0;
  }

  .a24s-hero__heading {
    font-size: clamp(1.6rem, 1.2rem + 3vw, 2.2rem);
  }

  .a24s-hero__phone-number {
    font-size: clamp(1.4rem, 1rem + 2vw, 1.6rem);
  }

  .a24s-hero__breadcrumb {
    margin-bottom: var(--space-1);
  }
  .a24s-hero__breadcrumb li {
    font-size: 11px;
  }

  .a24s-hero__urgent-badge {
    font-size: 10px;
    padding: 4px 12px;
  }

  .a24s-hero__channels {
    flex-wrap: wrap;
  }
  .a24s-hero__channel {
    max-width: none;
    flex: 1 1 auto;
  }

  .a24s-hero__trust {
    gap: 12px;
  }

  .a24s-hero__scroll {
    display: none;
  }

  .a24s-hero__photo {
    border-radius: 0;
  }

  /* Photo entrance: fade only on mobile */
  .a24s-hero__photo.a24s-anim {
    transform: translateY(0);
  }
}

/* ── Responsive: small mobile ── */
@media (max-width: 480px) {
  .a24s-hero__channels {
    gap: 6px;
  }
  .a24s-hero__channel {
    padding: 6px 14px;
    font-size: 11px;
  }
  .a24s-hero__trust-item {
    font-size: 12px;
  }
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  .a24s-anim,
  .a24s-hero__urgent-badge {
    opacity: 1;
    transform: none;
    animation: none;
  }
  .a24s-hero__dot::after,
  .a24s-hero__avail-dot,
  .a24s-hero__urgent-dot,
  .a24s-hero__bg-pulse,
  .a24s-hero__topline,
  .a24s-hero__scroll-line,
  .a24s-hero__photo-frame::after {
    animation: none;
  }
}

/* ============================================================
   E24-CALLOUT — „Co musisz wiedzieć teraz"
   Split layout: callout left (60%) + contact card right (40%).
   Dark theme, continues hero emergency atmosphere.
   Prefix: e24-callout, e24-contact-card
   ============================================================ */

/* ── Section ── */
.e24-callout-section {
  background: #0A0A0A;
  padding: 0 0 clamp(40px, 5vw, 64px);
  position: relative;
  overflow: hidden;
}

/* Subtle grid pattern (matches hero) */
.e24-callout-section__grid-bg {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.012) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.012) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
}

/* ── Callout header: heading + badge ── */
.e24-callout__header {
  display: flex;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.e24-callout__heading {
  font-family: var(--font-display);
  font-size: clamp(1.1rem, 0.9rem + 1vw, 1.35rem);
  font-weight: 600;
  color: var(--text-inverse);
  line-height: 1.3;
}
.e24-callout__heading em {
  font-style: normal;
  color: #FF6B6B;
}
.e24-callout__badge {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--dark-text-muted);
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  padding: 4px 10px;
  border-radius: 100px;
  white-space: nowrap;
}

/* ── Split grid ── */
.e24-callout-grid {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: clamp(24px, 4vw, 40px);
  align-items: stretch;
  position: relative;
  z-index: 1;
}

/* ── Left: Callout box ── */
.e24-callout {
  background: rgba(255,255,255,0.03);
  border-left: 4px solid #DC3232;
  border-radius: 0 14px 14px 0;
  padding: 28px 32px;
  border-top: 1px solid rgba(255,255,255,0.05);
  border-right: 1px solid rgba(255,255,255,0.05);
  border-bottom: 1px solid rgba(255,255,255,0.05);
  position: relative;
}

/* Scroll reveal (progressive enhancement) */
.e24-callout.e24-anim-ready {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}
.e24-callout.e24-anim-ready.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Title with icon */
.e24-callout__title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 700;
  color: var(--text-inverse);
  line-height: 1.3;
  margin-bottom: 16px;
}
.e24-callout__title-icon {
  width: 20px;
  height: 20px;
  stroke: #FF6B6B;
  flex-shrink: 0;
}

/* List */
.e24-callout__list {
  list-style: none;
  padding: 0;
  margin: 0;
}
/* Each item is a two-column mini-grid: keyword tag left, text right.
   This keeps all text aligned regardless of tag width. */
.e24-callout__item {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 0 12px;
  align-items: baseline;
  margin-bottom: 10px;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 400;
  color: var(--dark-text-secondary);
  line-height: 1.7;
}
.e24-callout__item:last-child {
  margin-bottom: 0;
}

/* Keyword tag: fixed-width left column */
.e24-callout__item strong {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #FF6B6B;
  background: rgba(220,50,50,0.08);
  border: 1px solid rgba(220,50,50,0.12);
  padding: 3px 0;
  border-radius: 4px;
  line-height: 1;
  white-space: nowrap;
}

/* CTA variant (last point): spans full width, no grid */
.e24-callout__item--cta {
  grid-column: 1 / -1;
  display: block;
  font-weight: 700;
  color: #FF6B6B;
  background: rgba(220,50,50,0.06);
  margin-left: -12px;
  margin-right: -12px;
  padding: 10px 12px;
  border-radius: 8px;
  border-left: 2px solid rgba(220,50,50,0.3);
}

/* ── Right: Contact card (matches a24-card design) ── */
.e24-contact-card {
  background: linear-gradient(170deg,
    rgba(60,20,20,0.4) 0%,
    rgba(13,13,13,0.95) 40%,
    rgba(13,13,13,0.95) 60%,
    rgba(50,15,15,0.3) 100%
  );
  border-radius: 20px;
  border: 1px solid rgba(220,50,50,0.15);
  padding: clamp(24px, 3vw, 36px) clamp(20px, 2.5vw, 32px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 8px;
  position: relative;
  overflow: hidden;
}

/* Noise texture overlay */
.e24-contact-card::before {
  content: '';
  position: absolute;
  inset: 0;
  opacity: 0.03;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 128px 128px;
  pointer-events: none;
  mix-blend-mode: overlay;
}

/* Scroll reveal */
.e24-contact-card.e24-anim-ready {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1) 0.15s,
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1) 0.15s;
}
.e24-contact-card.e24-anim-ready.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Urgency countdown */
.e24-contact-card__urgency {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  border-radius: 100px;
  background: rgba(220,50,50,0.1);
  border: 1px solid rgba(220,50,50,0.25);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #FF6B6B;
  margin-bottom: 8px;
  position: relative;
  z-index: 1;
  animation: a24UrgentPulse 2.5s ease-in-out infinite;
}
.e24-contact-card__urgency svg {
  width: 14px;
  height: 14px;
  stroke: #FF6B6B;
}
.e24-contact-card__urgency-dot {
  width: 6px;
  height: 6px;
  background: #DC3232;
  border-radius: 50%;
  flex-shrink: 0;
  animation: a24UrgentDotBlink 1.5s ease-in-out infinite;
}

/* Phone number */
.e24-contact-card__phone {
  font-family: var(--font-body);
  font-size: clamp(1.4rem, 1.1rem + 1.5vw, 1.75rem);
  font-weight: 700;
  color: var(--emergency-text);
  text-decoration: none;
  letter-spacing: 0.04em;
  line-height: 1.1;
  padding: 4px 0;
  transition: all 0.3s ease;
  position: relative;
  z-index: 1;
}
.e24-contact-card__phone:hover {
  color: #FF6B6B;
  text-shadow: 0 0 30px rgba(220,50,50,0.35);
}
.e24-contact-card__phone:focus-visible {
  outline: 2px solid #FF6B6B;
  outline-offset: 6px;
  border-radius: 4px;
}

/* Label */
.e24-contact-card__label {
  font-size: 12px;
  font-weight: 600;
  color: var(--dark-text-muted);
  letter-spacing: 0.5px;
  margin-bottom: 12px;
  position: relative;
  z-index: 1;
}

/* Divider */
.e24-contact-card__divider {
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--dark-border) 20%, var(--dark-border) 80%, transparent 100%);
  margin: 8px 0;
  position: relative;
  z-index: 1;
}

/* Messaging label */
.e24-contact-card__msg-label {
  font-size: 13px;
  color: var(--dark-text-muted);
  margin-top: 8px;
  margin-bottom: 4px;
  position: relative;
  z-index: 1;
}

/* Channel buttons */
.e24-contact-card__channels {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 4px;
  position: relative;
  z-index: 1;
  width: 100%;
}
.e24-contact-card__channel {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  flex: 1;
  padding: 10px 16px;
  border-radius: 10px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  color: var(--dark-text-secondary);
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.3s ease;
}
.e24-contact-card__channel:hover {
  background: rgba(220,50,50,0.1);
  border-color: rgba(220,50,50,0.3);
  color: #FF6B6B;
  transform: translateY(-1px);
}
.e24-contact-card__channel:focus-visible {
  outline: 2px solid #FF6B6B;
  outline-offset: 2px;
}
.e24-contact-card__channel svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

/* Trust signals */
.e24-contact-card__trust {
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 100%;
  position: relative;
  z-index: 1;
}
.e24-contact-card__trust-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  font-weight: 500;
  color: var(--dark-text-muted);
}
.e24-contact-card__trust-item svg {
  width: 16px;
  height: 16px;
  stroke: #FF6B6B;
  flex-shrink: 0;
}

/* Toggle hidden on desktop */
.e24-callout__toggle {
  display: none;
}

/* ── Responsive: tablet + mobile ── */
@media (max-width: 960px) {
  .e24-callout-section {
    padding: clamp(32px, 4vw, 48px) 0;
  }

  .e24-callout-grid {
    grid-template-columns: 1fr;
    gap: var(--space-3);
  }

  /* Callout: full-width clean card */
  .e24-callout {
    padding: 20px;
    border-left-width: 3px;
    border-radius: 0 12px 12px 0;
  }

  .e24-callout__title {
    font-size: 15px;
    margin-bottom: 12px;
    gap: 8px;
  }

  .e24-callout__title-icon {
    width: 18px;
    height: 18px;
  }

  .e24-callout__item {
    grid-template-columns: 68px 1fr;
    gap: 0 8px;
    font-size: 13px;
    margin-bottom: 8px;
    line-height: 1.6;
  }

  .e24-callout__item strong {
    font-size: 9px;
    padding: 2px 0;
  }

  .e24-callout__item--cta {
    margin-left: -8px;
    margin-right: -8px;
    padding: 8px 10px;
    font-size: 13px;
  }

  /* Callout collapse: hide items 4+ on mobile */
  .e24-callout__list .e24-callout__item:nth-child(n+4) {
    display: none;
  }
  .e24-callout__list.is-expanded .e24-callout__item:nth-child(n+4) {
    display: grid;
  }

  .e24-callout__toggle {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 10px;
    font-family: var(--font-body);
    font-size: 12px;
    font-weight: 600;
    color: #FF6B6B;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
  }
  .e24-callout__toggle svg {
    width: 16px;
    height: 16px;
    transition: transform 0.3s ease;
  }
  .e24-callout__toggle[aria-expanded="true"] svg {
    transform: rotate(180deg);
  }

  /* Contact card: compact horizontal strip */
  .e24-contact-card {
    border-radius: 12px;
    padding: 16px 20px;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    text-align: center;
    gap: 4px 12px;
  }

  .e24-contact-card__urgency {
    width: 100%;
    justify-content: center;
    margin-bottom: 4px;
    font-size: 10px;
    padding: 4px 10px;
  }

  .e24-contact-card__phone {
    font-size: 1.3rem;
  }

  .e24-contact-card__label {
    margin-bottom: 0;
    font-size: 11px;
  }

  .e24-contact-card__divider {
    width: 100%;
    margin: 4px 0;
  }

  .e24-contact-card__msg-label {
    width: 100%;
    margin-top: 0;
    margin-bottom: 2px;
    font-size: 12px;
  }

  .e24-contact-card__channels {
    justify-content: center;
  }

  .e24-contact-card__channel {
    flex: 0 1 auto;
    padding: 8px 18px;
    font-size: 12px;
    border-radius: 8px;
  }
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  .e24-callout.e24-anim-ready,
  .e24-contact-card.e24-anim-ready {
    opacity: 1;
    transform: none;
    transition: none;
  }
  .e24-contact-card__urgency,
  .e24-contact-card__urgency-dot {
    animation: none;
  }
}

/* ============================================================
   E24-TIMELINE — „Co zrobię po Twoim telefonie"
   Vertical timeline, sekcja 3 na podstronach Adwokat 24.
   Prefix: e24-timeline
   ============================================================ */

/* ── Section — slightly lighter dark to differentiate from callout ── */
.e24-timeline-section {
  background: #0D0D0D;
  padding: clamp(48px, 5vw, 80px) 0;
  position: relative;
  overflow: hidden;
  border-top: 1px solid rgba(220,50,50,0.08);
}
.e24-timeline-section::before {
  content: '';
  position: absolute;
  top: 10%;
  left: -8%;
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(220,50,50,0.03) 0%, transparent 60%);
  pointer-events: none;
}

/* Grid pattern (matches hero + callout) */
.e24-timeline-section::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.012) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.012) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
}

/* ── Header ── */
.e24-timeline-header {
  text-align: center;
  margin-bottom: clamp(36px, 4vw, 56px);
  position: relative;
  z-index: 1;
}

.e24-timeline__eyebrow {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: #FF6B6B;
  margin-bottom: 14px;
  display: block;
}
.e24-timeline__eyebrow::before {
  display: none;
}

.e24-timeline__headline {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 1.2rem + 1.5vw, 2.25rem);
  font-weight: 700;
  color: var(--text-inverse);
  line-height: 1.15;
}

/* ── Timeline container ── */
.e24-timeline {
  position: relative;
  max-width: 680px;
  margin: 0 auto;
  z-index: 1;
}

/* ── Progress line (left rail, fills on scroll) ── */
.e24-timeline__progress {
  position: absolute;
  top: 16px;
  left: 40px;
  transform: translateX(-50%);
  width: 2px;
  bottom: 16px;
  background: rgba(220,50,50,0.08);
  z-index: 0;
}
.e24-timeline__progress-fill {
  width: 100%;
  height: 0%;
  background: linear-gradient(to bottom, #DC3232, #FF6B6B);
  border-radius: 1px;
  transition: height 0.4s ease;
}

/* Active step (JS adds .is-active) */
.e24-timeline__step.is-active .e24-timeline__dot {
  background: #DC3232 !important;
  border-color: #DC3232 !important;
  box-shadow: 0 0 0 4px rgba(220,50,50,0.15) !important;
}
.e24-timeline__step.is-active .e24-timeline__number {
  color: #FFFFFF !important;
}

/* ── Step ── */
.e24-timeline__step {
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: 20px;
  align-items: start;
  padding-bottom: 32px;
  position: relative;
  border-radius: 12px;
  padding: 16px;
  margin: -16px;
  margin-bottom: 0;
  transition: background 0.3s ease;
}
.e24-timeline__step:last-child {
  padding-bottom: 16px;
}

/* Connecting line (pseudo-element) */
.e24-timeline__step::after {
  content: '';
  position: absolute;
  top: 52px;
  left: 40px;
  transform: translateX(-50%);
  width: 2px;
  bottom: 0;
  background: rgba(220,50,50,0.2);
  transform-origin: top;
}
.e24-timeline__step:last-child::after {
  display: none;
}

/* ── Marker ── */
.e24-timeline__marker {
  display: flex;
  justify-content: center;
}

.e24-timeline__dot {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 2;
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.e24-timeline__number {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 600;
  line-height: 1;
  transition: color 0.4s ease;
}

/* First step: filled dot */
.e24-timeline__step:first-child .e24-timeline__dot {
  background: #DC3232;
  box-shadow: 0 0 0 4px rgba(220,50,50,0.15);
}
.e24-timeline__step:first-child .e24-timeline__number {
  color: #FFFFFF;
}

/* Other steps: outlined dot */
.e24-timeline__step:not(:first-child) .e24-timeline__dot {
  background: transparent;
  border: 2px solid rgba(220,50,50,0.25);
}
.e24-timeline__step:not(:first-child) .e24-timeline__number {
  color: #FF6B6B;
}

/* ── Content ── */
.e24-timeline__content {
  padding-top: 4px;
}

.e24-timeline__title {
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 700;
  color: var(--text-inverse);
  line-height: 1.3;
  margin-bottom: 6px;
  transition: color 0.3s ease;
}

.e24-timeline__desc {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 400;
  color: var(--dark-text-secondary);
  line-height: 1.7;
}

/* Step badge (timing indicator) */
.e24-timeline__badge {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #FF6B6B;
  background: rgba(220,50,50,0.08);
  border: 1px solid rgba(220,50,50,0.15);
  padding: 3px 10px;
  border-radius: 100px;
  margin-bottom: 8px;
}

/* Checklist inside step */
.e24-timeline__checklist {
  list-style: none;
  padding: 0;
  margin: 10px 0 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.e24-timeline__checklist li {
  display: flex;
  align-items: baseline;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--dark-text-muted);
  line-height: 1.5;
}
.e24-timeline__checklist li::before {
  content: '';
  width: 5px;
  height: 5px;
  border-radius: 1px;
  background: rgba(220,50,50,0.3);
  flex-shrink: 0;
  margin-top: 6px;
}

/* Note block inside step */
.e24-timeline__note {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-top: 12px;
  padding: 10px 14px;
  background: rgba(220,50,50,0.04);
  border-radius: 8px;
  border: 1px solid rgba(220,50,50,0.1);
}
.e24-timeline__note svg {
  width: 16px;
  height: 16px;
  stroke: #FF6B6B;
  flex-shrink: 0;
  margin-top: 1px;
}
.e24-timeline__note span {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--dark-text-muted);
  line-height: 1.5;
}

/* ── CTA pod timeline ── */
.e24-timeline-cta {
  text-align: center;
  max-width: 680px;
  margin: clamp(32px, 4vw, 48px) auto 0;
  position: relative;
  z-index: 1;
}
.e24-timeline-cta__phone {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 14px 32px;
  background: #DC3232;
  color: #FFFFFF;
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.04em;
  border-radius: 10px;
  text-decoration: none;
  transition: all 0.3s ease;
  box-shadow: 0 0 20px rgba(220,50,50,0.25);
}
.e24-timeline-cta__phone:hover {
  background: #E04040;
  box-shadow: 0 0 32px rgba(220,50,50,0.45);
  transform: translateY(-2px);
}
.e24-timeline-cta__phone:focus-visible {
  outline: 2px solid #FF6B6B;
  outline-offset: 4px;
}
.e24-timeline-cta__phone svg {
  width: 20px;
  height: 20px;
}
.e24-timeline-cta__label {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--dark-text-muted);
  margin-top: 12px;
}

/* ── Hover on step (desktop) ── */
.e24-timeline__step:hover {
  background: rgba(220,50,50,0.02);
}
.e24-timeline__step:hover .e24-timeline__dot {
  background: #DC3232;
  border-color: #DC3232;
  box-shadow: 0 0 0 4px rgba(220,50,50,0.15);
}
.e24-timeline__step:hover .e24-timeline__number {
  color: #FFFFFF;
}
.e24-timeline__step:hover .e24-timeline__title {
  color: #FF6B6B;
}

/* ── Scroll reveal (progressive enhancement) ──
   JS adds .e24-tl-ready to hide elements, then .is-visible to reveal.
   Without JS, everything is visible. */
.e24-timeline.e24-tl-ready .e24-timeline__dot {
  opacity: 0;
  transform: scale(0.6);
  transition: opacity 0.6s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}
.e24-timeline.e24-tl-ready .e24-timeline__step::after {
  transform: translateX(-50%) scaleY(0);
  transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}
.e24-timeline.e24-tl-ready .e24-timeline__content {
  opacity: 0;
  transform: translateX(12px);
  transition: opacity 0.6s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}
.e24-timeline.e24-tl-ready .e24-timeline-header {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Revealed state — sequential cascade */
.e24-timeline.e24-tl-ready.is-visible .e24-timeline-header {
  opacity: 1; transform: translateY(0);
}

.e24-timeline.e24-tl-ready.is-visible .e24-timeline__step:nth-child(1) .e24-timeline__dot { opacity: 1; transform: scale(1); transition-delay: 0.15s; }
.e24-timeline.e24-tl-ready.is-visible .e24-timeline__step:nth-child(1)::after { transform: translateX(-50%) scaleY(1); transition-delay: 0.25s; }
.e24-timeline.e24-tl-ready.is-visible .e24-timeline__step:nth-child(1) .e24-timeline__content { opacity: 1; transform: translateX(0); transition-delay: 0.2s; }

.e24-timeline.e24-tl-ready.is-visible .e24-timeline__step:nth-child(2) .e24-timeline__dot { opacity: 1; transform: scale(1); transition-delay: 0.35s; }
.e24-timeline.e24-tl-ready.is-visible .e24-timeline__step:nth-child(2)::after { transform: translateX(-50%) scaleY(1); transition-delay: 0.45s; }
.e24-timeline.e24-tl-ready.is-visible .e24-timeline__step:nth-child(2) .e24-timeline__content { opacity: 1; transform: translateX(0); transition-delay: 0.4s; }

.e24-timeline.e24-tl-ready.is-visible .e24-timeline__step:nth-child(3) .e24-timeline__dot { opacity: 1; transform: scale(1); transition-delay: 0.55s; }
.e24-timeline.e24-tl-ready.is-visible .e24-timeline__step:nth-child(3)::after { transform: translateX(-50%) scaleY(1); transition-delay: 0.65s; }
.e24-timeline.e24-tl-ready.is-visible .e24-timeline__step:nth-child(3) .e24-timeline__content { opacity: 1; transform: translateX(0); transition-delay: 0.6s; }

.e24-timeline.e24-tl-ready.is-visible .e24-timeline__step:nth-child(4) .e24-timeline__dot { opacity: 1; transform: scale(1); transition-delay: 0.75s; }
.e24-timeline.e24-tl-ready.is-visible .e24-timeline__step:nth-child(4) .e24-timeline__content { opacity: 1; transform: translateX(0); transition-delay: 0.8s; }

/* ── Responsive: mobile ── */
@media (max-width: 767px) {
  .e24-timeline__step {
    grid-template-columns: 36px 1fr;
    gap: 14px;
    padding: 12px;
    margin: -12px;
    margin-bottom: 0;
    padding-bottom: 24px;
    border-radius: 10px;
  }
  .e24-timeline__step:last-child {
    padding-bottom: 12px;
  }

  .e24-timeline__dot {
    width: 28px;
    height: 28px;
  }

  .e24-timeline__number {
    font-size: 13px;
  }

  .e24-timeline__step::after {
    left: 30px;
    width: 1.5px;
    top: 40px;
  }

  .e24-timeline__progress {
    left: 30px;
  }

  .e24-timeline__title {
    font-size: 14px;
  }

  .e24-timeline__desc {
    font-size: 13px;
  }

  .e24-timeline__badge {
    font-size: 9px;
    padding: 2px 8px;
  }

  .e24-timeline__checklist li {
    font-size: 12px;
  }

  .e24-timeline__note {
    padding: 8px 10px;
    gap: 8px;
  }
  .e24-timeline__note span {
    font-size: 12px;
  }

  .e24-timeline__headline {
    font-size: clamp(1.3rem, 1rem + 1.5vw, 1.6rem);
  }
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  .e24-timeline.e24-tl-ready .e24-timeline__dot,
  .e24-timeline.e24-tl-ready .e24-timeline__content,
  .e24-timeline.e24-tl-ready .e24-timeline-header {
    opacity: 1;
    transform: none;
    transition: none;
  }
  .e24-timeline.e24-tl-ready .e24-timeline__step::after {
    transform: translateX(-50%) scaleY(1);
    transition: none;
  }
}

/* ============================================================
   EXPERT--DARK — Dark emergency override for Adwokat 24 subpages
   Scoped to .expert--dark. Overrides light-theme expert styles
   to match the red emergency palette used across the page.
   ============================================================ */

/* Section background */
.expert--dark {
  background: #0A0A0A;
  position: relative;
}
.expert--dark::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.012) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.012) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
}

/* Header */
.expert--dark .expert__eyebrow {
  color: #FF6B6B;
}
.expert--dark .expert__headline {
  color: var(--text-inverse);
}
.expert--dark .expert__headline em {
  color: #FF6B6B;
}

/* Segment titles and body */
.expert--dark .segment__title {
  color: var(--text-inverse);
}
.expert--dark .segment__body {
  color: var(--dark-text-secondary);
}
.expert--dark .segment__body strong {
  color: var(--text-inverse);
}
.expert--dark .segment__body h4 {
  color: var(--text-inverse);
}
.expert--dark .segment__body a {
  color: #FF6B6B;
  text-decoration-color: rgba(220,50,50,0.3);
}
.expert--dark .segment__body a:hover {
  color: #FF8A8A;
}

/* Segment icon */
.expert--dark .segment__icon {
  background: rgba(220,50,50,0.08);
  border-color: rgba(220,50,50,0.15);
}
.expert--dark .segment__icon svg {
  stroke: #FF6B6B;
}

/* Even segment alternating bg */
.expert--dark .segment:nth-child(even) .segment__inner {
  background: rgba(255,255,255,0.02);
  border-color: rgba(255,255,255,0.05);
}

/* Segment--dark (the "alert" variant) */
.expert--dark .segment--dark {
  background: rgba(220,50,50,0.03);
  border-color: rgba(220,50,50,0.1);
}

/* List markers */
.expert--dark .segment__body ul li::before {
  background: rgba(220,50,50,0.15);
  border-color: rgba(220,50,50,0.3);
}

/* Trust callout */
.expert--dark .segment__trust-callout {
  background: rgba(255,255,255,0.02);
  border-color: rgba(255,255,255,0.06);
}
.expert--dark .segment__trust-callout-number {
  color: #FF6B6B;
}
.expert--dark .segment__trust-callout-label {
  color: var(--dark-text-muted);
}
.expert--dark .segment__trust-callout-sep {
  background: rgba(255,255,255,0.06);
}

/* Stat pullquote */
.expert--dark .segment__stat {
  background: rgba(220,50,50,0.04);
  border-color: rgba(220,50,50,0.1);
}
.expert--dark .segment__stat-icon svg {
  stroke: #FF6B6B;
}
.expert--dark .segment__stat p {
  color: var(--dark-text-secondary);
}

/* Penalty cards */
.expert--dark .penalty-card {
  background: rgba(255,255,255,0.03);
  border-color: rgba(255,255,255,0.06);
}
.expert--dark .penalty-card__title {
  color: var(--text-inverse);
}
.expert--dark .penalty-card__penalty {
  color: #FF6B6B;
}
.expert--dark .penalty-card__desc {
  color: var(--dark-text-muted);
}
.expert--dark .penalty-card__badge {
  color: #FF6B6B;
  background: rgba(220,50,50,0.1);
  border-color: rgba(220,50,50,0.2);
}
.expert--dark .penalty-card--severe {
  border-color: rgba(220,50,50,0.2);
  background: rgba(220,50,50,0.04);
}
.expert--dark .penalty-card--mitigated {
  border-color: rgba(74,154,106,0.2);
}

/* Inline CTA */
.expert--dark .inline-cta {
  background: rgba(255,255,255,0.03);
  border-color: rgba(220,50,50,0.15);
  box-shadow: none;
}
.expert--dark .inline-cta:hover {
  border-color: rgba(220,50,50,0.4);
}
.expert--dark .inline-cta__icon {
  background: rgba(220,50,50,0.08);
  border-color: rgba(220,50,50,0.15);
}
.expert--dark .inline-cta__icon svg {
  stroke: #FF6B6B;
}
.expert--dark .inline-cta__title {
  color: var(--text-inverse);
}
.expert--dark .inline-cta__desc {
  color: var(--dark-text-muted);
}
.expert--dark .inline-cta__phone {
  color: #FF6B6B;
}
.expert--dark .inline-cta__phone:hover {
  color: #FF8A8A;
}

/* Inline CTA urgent variant */
.expert--dark .inline-cta--urgent {
  border-color: rgba(220,50,50,0.25);
  background: rgba(220,50,50,0.04);
}

/* Bottom CTA */
.expert--dark .expert__bottom-cta {
  background: rgba(220,50,50,0.04);
  border-color: rgba(220,50,50,0.15);
}
.expert--dark .expert__bottom-cta::before {
  background: radial-gradient(ellipse at 30% 50%, rgba(220,50,50,0.06) 0%, transparent 60%);
}
.expert--dark .expert__bottom-cta-title {
  color: var(--text-inverse);
}
.expert--dark .expert__bottom-cta-desc {
  color: var(--dark-text-secondary);
}
.expert--dark .expert__bottom-cta-footnote {
  color: var(--dark-text-muted);
}
.expert--dark .expert__bottom-cta-actions .btn-accent {
  background: #DC3232;
}
.expert--dark .expert__bottom-cta-actions .btn-accent:hover {
  background: #E04040;
}

/* TOC sidebar */
.expert--dark .toc {
  background: rgba(255,255,255,0.03);
  border-color: rgba(255,255,255,0.06);
  box-shadow: none;
}
.expert--dark .toc__title {
  color: #FF6B6B;
  border-bottom-color: rgba(255,255,255,0.06);
}
.expert--dark .toc__list {
  border-left-color: rgba(255,255,255,0.06);
}
.expert--dark .toc__link {
  color: var(--dark-text-muted);
}
.expert--dark .toc__link:hover {
  color: var(--dark-text-secondary);
  border-left-color: rgba(220,50,50,0.3);
}
.expert--dark .toc__link.is-active {
  color: #FF6B6B;
  border-left-color: #DC3232;
}
.expert--dark .toc__cta {
  border-top-color: rgba(255,255,255,0.06);
}
.expert--dark .toc__cta-phone {
  color: #FF6B6B;
}
.expert--dark .toc__cta-phone:hover {
  color: #FF8A8A;
}
.expert--dark .toc__cta-label {
  color: var(--dark-text-muted);
}

/* Sidebar form */
.expert--dark .sidebar-form {
  background: rgba(255,255,255,0.03);
  border-color: rgba(255,255,255,0.06);
  box-shadow: none;
}
.expert--dark .sidebar-form__title {
  color: var(--text-inverse);
}
.expert--dark .sidebar-form__input {
  background: rgba(255,255,255,0.04);
  border-color: rgba(255,255,255,0.08);
  color: var(--text-inverse);
}
.expert--dark .sidebar-form__input::placeholder {
  color: var(--dark-text-muted);
}
.expert--dark .sidebar-form__input:focus {
  border-color: #DC3232;
  box-shadow: 0 0 0 3px rgba(220,50,50,0.1);
}
.expert--dark .sidebar-form__btn {
  background: #DC3232;
}
.expert--dark .sidebar-form__btn:hover {
  background: #E04040;
}
.expert--dark .sidebar-form__privacy {
  color: var(--dark-text-muted);
}

/* Sidebar urgency */
.expert--dark .sidebar-urgency {
  background: rgba(220,50,50,0.04);
  border-color: rgba(220,50,50,0.12);
}
.expert--dark .sidebar-urgency__text {
  color: var(--dark-text-muted);
}
.expert--dark .sidebar-urgency__text strong {
  color: var(--dark-text-secondary);
}
.expert--dark .sidebar-urgency__phone {
  color: #FF6B6B;
}

/* KK badge */
.expert--dark .kk-badge {
  background: rgba(220,50,50,0.08);
  border-color: rgba(220,50,50,0.15);
  color: #FF6B6B;
}

/* ============================================================
   SIDEBAR DOCS CARD (Option 1 — Expert sidebar)
   ============================================================ */
.sidebar-docs {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 20px;
  padding: 20px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 14px;
  text-decoration: none;
  transition: border-color 0.3s ease, background 0.3s ease;
}
.sidebar-docs:hover {
  border-color: rgba(220,50,50,0.3);
  background: rgba(220,50,50,0.04);
}
.sidebar-docs__icon {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: rgba(220,50,50,0.08);
  border: 1px solid rgba(220,50,50,0.15);
  display: flex;
  align-items: center;
  justify-content: center;
}
.sidebar-docs__icon svg {
  width: 20px;
  height: 20px;
  stroke: #FF6B6B;
}
.sidebar-docs__text {
  flex: 1;
  min-width: 0;
}
.sidebar-docs__title {
  display: block;
  font-size: 13px;
  font-weight: 700;
  color: var(--text-inverse);
  margin-bottom: 2px;
}
.sidebar-docs__desc {
  display: block;
  font-size: 11px;
  line-height: 1.4;
  color: var(--dark-text-muted);
}
.sidebar-docs__arrow {
  flex-shrink: 0;
}
.sidebar-docs__arrow svg {
  width: 18px;
  height: 18px;
  stroke: rgba(255,255,255,0.25);
  transition: stroke 0.3s ease, transform 0.3s ease;
}
.sidebar-docs:hover .sidebar-docs__arrow svg {
  stroke: #FF6B6B;
  transform: translateX(3px);
}

/* ============================================================
   INLINE CTA — DOCS VARIANT (Option 2)
   ============================================================ */
.inline-cta--docs {
  text-decoration: none;
  cursor: pointer;
}
.inline-cta--docs .inline-cta__badge {
  flex-shrink: 0;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  padding: 4px 10px;
  border-radius: 20px;
  white-space: nowrap;
}
.inline-cta--docs .inline-cta__arrow {
  flex-shrink: 0;
}
.inline-cta--docs .inline-cta__arrow svg {
  width: 20px;
  height: 20px;
  transition: transform 0.3s ease;
}
.inline-cta--docs:hover .inline-cta__arrow svg {
  transform: translateX(3px);
}

/* Dark theme (inside expert--dark) */
.expert--dark .inline-cta--docs {
  background: rgba(255,255,255,0.03);
  border-color: rgba(255,255,255,0.08);
}
.expert--dark .inline-cta--docs:hover {
  border-color: rgba(220,50,50,0.3);
  background: rgba(220,50,50,0.04);
}
.expert--dark .inline-cta--docs .inline-cta__icon {
  background: rgba(220,50,50,0.08);
  border-color: rgba(220,50,50,0.15);
}
.expert--dark .inline-cta--docs .inline-cta__icon svg {
  stroke: #FF6B6B;
}
.expert--dark .inline-cta--docs .inline-cta__title {
  color: var(--text-inverse);
}
.expert--dark .inline-cta--docs .inline-cta__desc {
  color: var(--dark-text-muted);
}
.expert--dark .inline-cta--docs .inline-cta__badge {
  background: rgba(220,50,50,0.1);
  color: #FF6B6B;
}
.expert--dark .inline-cta--docs .inline-cta__arrow svg {
  stroke: rgba(255,255,255,0.3);
}
.expert--dark .inline-cta--docs:hover .inline-cta__arrow svg {
  stroke: #FF6B6B;
}

/* ============================================================
   FAQ SIDEBAR — DOCS CARD (Option 3)
   ============================================================ */
.faq__sidebar-card--docs {
  display: block;
  margin-top: 16px;
  text-decoration: none;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}
.faq__sidebar-card--docs:hover {
  border-color: var(--accent);
  box-shadow: var(--shadow-md);
}
.faq__sidebar-card--docs .faq__sidebar-icon svg {
  fill: none;
  stroke: var(--accent);
  stroke-width: 1.5;
}
.faq__sidebar-card--docs .btn-secondary {
  display: inline-flex;
  align-items: center;
  margin-top: 12px;
  font-size: 13px;
  font-weight: 600;
  color: var(--accent);
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  transition: color 0.2s ease;
}
.faq__sidebar-card--docs:hover .btn-secondary {
  color: var(--accent-hover, var(--accent));
}

/* ============================================================
   DOCUMENTS SHOWCASE SECTION (Option 4)
   ============================================================ */
.docs-showcase {
  position: relative;
  background: #0A0A0A;
  padding: clamp(48px, 6vw, 80px) 0;
  overflow: hidden;
}
.docs-showcase__grid-bg {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
}
.docs-showcase__header {
  text-align: center;
  margin-bottom: clamp(24px, 3vw, 40px);
}
.docs-showcase__eyebrow {
  display: block;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #FF6B6B;
  margin-bottom: 8px;
}
.docs-showcase__headline {
  font-size: clamp(1.4rem, 1rem + 2vw, 2rem);
  font-weight: 800;
  color: #fff;
  margin: 0 0 8px;
}
.docs-showcase__sub {
  font-size: 0.95rem;
  color: rgba(255,255,255,0.5);
  max-width: 520px;
  margin: 0 auto;
  line-height: 1.6;
}

/* Cards grid */
.docs-showcase__cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 16px;
  margin-bottom: clamp(24px, 3vw, 40px);
}
.docs-showcase__card {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 20px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 12px;
  text-decoration: none;
  transition: border-color 0.3s ease, background 0.3s ease;
}
.docs-showcase__card:hover {
  border-color: rgba(220,50,50,0.3);
  background: rgba(220,50,50,0.04);
}
.docs-showcase__card-icon {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  border-radius: 10px;
  background: rgba(220,50,50,0.08);
  border: 1px solid rgba(220,50,50,0.15);
  display: flex;
  align-items: center;
  justify-content: center;
}
.docs-showcase__card-icon svg {
  width: 22px;
  height: 22px;
  stroke: #FF6B6B;
}
.docs-showcase__card-content {
  flex: 1;
  min-width: 0;
}
.docs-showcase__card-title {
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  margin: 0 0 2px;
}
.docs-showcase__card-desc {
  font-size: 12px;
  color: rgba(255,255,255,0.45);
  line-height: 1.4;
  margin: 0;
}
.docs-showcase__card-price {
  flex-shrink: 0;
  font-size: 13px;
  font-weight: 700;
  color: #FF6B6B;
  padding: 4px 10px;
  background: rgba(220,50,50,0.08);
  border-radius: 20px;
  white-space: nowrap;
}
.docs-showcase__card-arrow {
  flex-shrink: 0;
}
.docs-showcase__card-arrow svg {
  width: 18px;
  height: 18px;
  stroke: rgba(255,255,255,0.2);
  transition: stroke 0.3s ease, transform 0.3s ease;
}
.docs-showcase__card:hover .docs-showcase__card-arrow svg {
  stroke: #FF6B6B;
  transform: translateX(3px);
}

/* CTA */
.docs-showcase__cta {
  text-align: center;
}
.docs-showcase__btn {
  display: inline-flex;
  align-items: center;
  padding: 12px 28px;
  font-size: 14px;
  font-weight: 600;
  color: #fff;
  background: rgba(220,50,50,0.1);
  border: 1px solid rgba(220,50,50,0.25);
  border-radius: 10px;
  text-decoration: none;
  transition: background 0.3s ease, border-color 0.3s ease;
}
.docs-showcase__btn:hover {
  background: rgba(220,50,50,0.18);
  border-color: rgba(220,50,50,0.4);
}

/* Responsive */
@media (max-width: 600px) {
  .docs-showcase__cards {
    grid-template-columns: 1fr;
  }
}

/* ============================================================
   RELATED CARD — DOCS VARIANT (Option 5)
   ============================================================ */
.related__card--docs .related__card-badge {
  background: var(--accent-bg-solid, rgba(220,50,50,0.08));
  color: var(--accent, #DC3232);
}

/* ============================================================
   CENNIK HERO
   ============================================================ */
.cennik-hero {
  position: relative;
  background: var(--dark-bg);
  padding: clamp(120px, 14vw, 200px) 0 clamp(48px, 5vw, 72px);
  overflow: hidden;
}

/* Subtle radial glow — green, not emergency */
.cennik-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 70% 50% at 30% 60%, rgba(46,107,71,0.06) 0%, transparent 70%),
    radial-gradient(ellipse 40% 60% at 80% 20%, rgba(46,107,71,0.04) 0%, transparent 60%);
  pointer-events: none;
}

/* Top accent line */
.cennik-hero__topline {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--accent-light), var(--accent), var(--accent-light), transparent);
  opacity: 0.45;
}

/* Breadcrumb */
.cennik-hero__breadcrumb {
  margin-bottom: var(--space-4);
  opacity: 0;
  animation: fadeInUp 0.6s ease-out 0.1s forwards;
}
.cennik-hero__breadcrumb ol {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  list-style: none;
}
.cennik-hero__breadcrumb li {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.03em;
  color: var(--dark-text-muted);
}
.cennik-hero__breadcrumb li a {
  color: var(--dark-text-muted);
  transition: color 0.2s ease;
}
.cennik-hero__breadcrumb li a:hover {
  color: var(--accent-light);
}
.cennik-hero__breadcrumb li + li::before {
  content: '›';
  margin: 0 10px;
  color: var(--dark-border);
  font-size: 14px;
}
.cennik-hero__breadcrumb li[aria-current="page"] {
  color: var(--dark-text-secondary);
}

/* Content block */
.cennik-hero__content {
  max-width: 720px;
  margin: 0 auto var(--space-5);
  text-align: center;
}

/* H1 */
.cennik-hero__heading {
  font-family: var(--font-display);
  font-size: clamp(2rem, 1.4rem + 3vw, 3.25rem);
  font-weight: 700;
  line-height: 1.12;
  letter-spacing: -0.02em;
  color: var(--text-inverse);
  margin-bottom: var(--space-2);
  opacity: 0;
  animation: fadeInUp 0.7s ease-out 0.2s forwards;
}

/* Lead */
.cennik-hero__lead {
  font-family: var(--font-body);
  font-size: clamp(1.05rem, 0.95rem + 0.5vw, 1.2rem);
  font-weight: 400;
  line-height: 1.65;
  color: var(--dark-text-secondary);
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
  opacity: 0;
  animation: fadeInUp 0.7s ease-out 0.35s forwards;
}

/* Trust bar */
.cennik-hero__trust {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  flex-wrap: wrap;
  opacity: 0;
  animation: fadeInUp 0.7s ease-out 0.5s forwards;
}
.cennik-hero__trust-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--dark-text-muted);
}
.cennik-hero__trust-item strong {
  color: var(--dark-text-secondary);
  font-weight: 600;
}
.cennik-hero__trust-item svg {
  width: 16px;
  height: 16px;
  stroke: var(--accent-light);
  fill: none;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex-shrink: 0;
}
.cennik-hero__trust-sep {
  width: 1px;
  height: 16px;
  background: var(--dark-border);
}

/* Scroll indicator */
.cennik-hero__scroll {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: var(--space-5);
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--dark-text-muted);
  transition: color 0.25s ease;
  opacity: 0;
  animation: fadeInUp 0.7s ease-out 0.65s forwards;
}
.cennik-hero__scroll:hover {
  color: var(--accent-light);
}
.cennik-hero__scroll svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  animation: cennikScrollBounce 2s ease-in-out 1.5s infinite;
}
@keyframes cennikScrollBounce {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(4px); }
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  .cennik-hero__breadcrumb,
  .cennik-hero__heading,
  .cennik-hero__lead,
  .cennik-hero__trust,
  .cennik-hero__scroll {
    opacity: 1;
    animation: none;
  }
  .cennik-hero__scroll svg {
    animation: none;
  }
}

/* ── Responsive ── */
@media (max-width: 640px) {
  .cennik-hero {
    padding: clamp(100px, 12vw, 160px) 0 clamp(36px, 4vw, 56px);
  }
  .cennik-hero__trust {
    gap: var(--space-2);
  }
  .cennik-hero__trust-sep {
    display: none;
  }
  .cennik-hero__trust-item {
    padding: 6px 12px;
    background: rgba(46,107,71,0.06);
    border: 1px solid rgba(46,107,71,0.12);
    border-radius: 100px;
    font-size: 12px;
  }
}


/* ============================================================
   SEKCJA 2: MODEL ROZLICZEŃ (PRICING)
   ============================================================ */
.pricing {
  background: var(--bg-primary);
  padding: clamp(64px, 8vw, 120px) 0;
}

/* Header */
.pricing__header {
  text-align: center;
  margin-bottom: clamp(40px, 5vw, 64px);
}
.pricing__heading {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 1.2rem + 2.5vw, 2.75rem);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--text-primary);
  margin-bottom: var(--space-1);
}
.pricing__subheading {
  font-family: var(--font-body);
  font-size: clamp(0.95rem, 0.85rem + 0.5vw, 1.1rem);
  color: var(--text-tertiary);
  font-weight: 400;
}

/* Grid */
.pricing__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: start;
  gap: var(--space-3);
  max-width: 920px;
  margin: 0 auto;
}

/* ── Karta bazowa ── */
.pricing-card {
  position: relative;
  display: flex;
  flex-direction: column;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: clamp(28px, 3vw, 40px);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.pricing-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

/* Badge „Główny model" */
.pricing-card__badge {
  position: absolute;
  top: -1px;
  right: var(--space-4);
  padding: 6px 16px;
  background: var(--accent);
  color: #fff;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-radius: 0 0 8px 8px;
}

/* Card icon */
.pricing-card__icon {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--accent-bg-solid);
  border: 1px solid var(--accent-border-solid);
  border-radius: 12px;
  margin-bottom: 16px;
}
.pricing-card__icon svg {
  width: 22px;
  height: 22px;
  stroke: var(--accent);
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* Top area */
.pricing-card__top {
  margin-bottom: var(--space-3);
}
.pricing-card__eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 10px;
}
.pricing-card__title {
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 1.1rem + 1.5vw, 1.85rem);
  font-weight: 700;
  line-height: 1.15;
  color: var(--text-primary);
  margin-bottom: 10px;
}
.pricing-card__desc {
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.65;
  color: var(--text-tertiary);
}

/* Price block */
.pricing-card__price-block {
  display: flex;
  align-items: baseline;
  gap: 8px;
  padding: var(--space-3) 0;
  margin-bottom: var(--space-2);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.pricing-card__price {
  font-family: var(--font-display);
  font-size: clamp(2rem, 1.5rem + 2vw, 2.75rem);
  font-weight: 700;
  line-height: 1;
  color: var(--text-primary);
  letter-spacing: -0.02em;
}
.pricing-card__price-note {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  color: var(--text-muted);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

/* Price info tooltip trigger */
.pricing-card__price-info {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  padding: 0;
  background: none;
  border: none;
  cursor: help;
}
.pricing-card__price-info svg {
  width: 16px;
  height: 16px;
  stroke: var(--text-muted);
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: stroke 0.2s ease;
}
.pricing-card__price-info:hover svg {
  stroke: var(--accent);
}

/* Tooltip */
.pricing-card__price-info::after {
  content: attr(data-tooltip);
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
  padding: 8px 14px;
  background: var(--text-primary);
  color: var(--text-inverse);
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  line-height: 1.4;
  border-radius: 8px;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.2s ease;
  z-index: 10;
}
.pricing-card__price-info:hover::after,
.pricing-card__price-info:focus::after {
  opacity: 1;
}

/* Features list */
.pricing-card__features {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: var(--space-2);
  padding-top: var(--space-2);
}
.pricing-card__features li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.5;
  color: var(--text-secondary);
}

/* Hidden items — collapsed by default */
.pricing-card__features-more {
  display: none !important;
}
.pricing-card__features.is-expanded .pricing-card__features-more {
  display: flex !important;
}
.pricing-card__features svg {
  width: 18px;
  height: 18px;
  stroke: var(--accent);
  fill: none;
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex-shrink: 0;
  margin-top: 1px;
}

/* CTA button */
.pricing-card__cta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 24px;
  border-radius: 10px;
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.3s ease;
  margin-top: auto;
  background: transparent;
  color: var(--accent);
  border: 1.5px solid var(--accent-border-solid);
}
.pricing-card__cta svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex-shrink: 0;
}
.pricing-card__cta:hover {
  background: var(--accent-bg);
  border-color: var(--accent);
  transform: translateY(-2px);
}

/* Primary CTA variant */
.pricing-card__cta--primary {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
.pricing-card__cta--primary:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
  box-shadow: 0 8px 32px rgba(46,107,71,0.25);
}

/* Toggle "Pokaż wszystko" */
.pricing-card__toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0;
  margin-bottom: var(--space-3);
  background: none;
  border: none;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--accent);
  cursor: pointer;
  transition: color 0.2s ease;
}
.pricing-card__toggle:hover {
  color: var(--accent-hover);
}
.pricing-card__toggle svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: transform 0.3s ease;
}
.pricing-card__toggle[aria-expanded="true"] svg {
  transform: rotate(180deg);
}

/* CTA group */
.pricing-card__cta-group {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.pricing-card__cta-alt {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text-muted);
}
.pricing-card__cta-alt a {
  color: var(--accent);
  font-weight: 600;
  transition: color 0.2s ease;
}
.pricing-card__cta-alt a:hover {
  color: var(--accent-hover);
}

/* Highlighted card — subtle accent border */
.pricing-card--case {
  border-color: var(--accent-border-solid);
  box-shadow: var(--shadow-sm);
}

/* ── Scroll reveal (JS adds .pricing-card--reveal) ── */
.pricing-card--reveal {
  opacity: 0;
  transform: translateY(24px);
}
.pricing-card--reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}
.pricing-card--case.pricing-card--reveal.is-visible {
  transition-delay: 0.1s;
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  .pricing-card--reveal {
    opacity: 1;
    transform: none;
  }
}

/* ── Responsive ── */
@media (max-width: 720px) {
  .pricing__grid {
    grid-template-columns: 1fr;
    max-width: 480px;
  }
  .pricing-card--case {
    order: -1;
  }
}

/* ============================================================
   SEKCJA 3: DLACZEGO STAWKA GODZINOWA
   ============================================================ */
.why-hourly {
  background: var(--bg-secondary);
  padding: clamp(64px, 8vw, 120px) 0;
}

/* Grid: sticky intro + scrolling arguments */
.why-hourly__grid {
  display: grid;
  grid-template-columns: 0.42fr 0.58fr;
  gap: clamp(40px, 5vw, 80px);
  align-items: start;
}

/* Lewa kolumna — intro */
.why-hourly__intro {
  position: sticky;
  top: 120px;
}
.why-hourly__heading {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 1.2rem + 2.5vw, 2.75rem);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--text-primary);
  margin-bottom: var(--space-4);
}

/* Pull-quote */
.why-hourly__quote {
  position: relative;
  padding-left: var(--space-3);
  border-left: 3px solid var(--accent);
}
.why-hourly__quote p {
  font-family: var(--font-display);
  font-size: clamp(1.15rem, 1rem + 0.7vw, 1.4rem);
  font-weight: 500;
  font-style: italic;
  line-height: 1.55;
  color: var(--text-secondary);
}

/* Contact CTA */
.why-hourly__contact {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--border);
}
.why-hourly__contact-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--text-secondary);
  transition: color 0.2s ease;
}
.why-hourly__contact-link:hover {
  color: var(--accent);
}
.why-hourly__contact-link svg {
  width: 18px;
  height: 18px;
  stroke: var(--accent);
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex-shrink: 0;
}

/* Prawa kolumna — argumenty */
.why-hourly__arguments {
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* Pojedynczy argument */
.why-hourly__arg {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-4) 0;
  border-bottom: 1px solid var(--border);
}
.why-hourly__arg:first-child {
  padding-top: 0;
}
.why-hourly__arg:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

/* Numer */
.why-hourly__arg-num {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 1.2rem + 1vw, 2rem);
  font-weight: 700;
  line-height: 1.2;
  color: var(--accent-border-solid);
  flex-shrink: 0;
  min-width: 36px;
  user-select: none;
}

/* Treść argumentu */
.why-hourly__arg-title {
  font-family: var(--font-display);
  font-size: clamp(1.1rem, 0.95rem + 0.7vw, 1.35rem);
  font-weight: 700;
  line-height: 1.25;
  color: var(--text-primary);
  margin-bottom: 8px;
}
.why-hourly__arg-body p {
  font-family: var(--font-body);
  font-size: 14.5px;
  line-height: 1.7;
  color: var(--text-tertiary);
}

/* ── Scroll reveal ── */
.why-hourly__arg {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.5s ease-out, transform 0.5s ease-out;
}
.why-hourly__arg.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.why-hourly__intro {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}
.why-hourly__intro.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  .why-hourly__arg,
  .why-hourly__intro {
    opacity: 1;
    transform: none;
  }
}

/* ── Responsive ── */
@media (max-width: 820px) {
  .why-hourly__grid {
    grid-template-columns: 1fr;
    gap: var(--space-5);
  }
  .why-hourly__intro {
    position: static;
  }
}

/* ============================================================
   SEKCJA 5: CO WPŁYWA NA KOSZT SPRAWY
   ============================================================ */
.cost-factors {
  background: var(--bg-primary);
  padding: clamp(64px, 8vw, 120px) 0;
}

/* Header — two columns */
.cost-factors__header {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 4vw, 64px);
  align-items: start;
  margin-bottom: clamp(40px, 5vw, 64px);
}
.cost-factors__heading {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 1.2rem + 2.5vw, 2.75rem);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--text-primary);
  margin-bottom: var(--space-1);
}
.cost-factors__sub {
  font-family: var(--font-body);
  font-size: clamp(0.95rem, 0.85rem + 0.5vw, 1.1rem);
  color: var(--text-tertiary);
  line-height: 1.6;
}

/* Prompt CTA */
.cost-factors__prompt {
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--border);
}
.cost-factors__prompt p {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text-tertiary);
  margin-bottom: 12px;
}
.cost-factors__prompt-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 700;
  color: var(--accent);
  transition: color 0.2s ease;
}
.cost-factors__prompt-cta:hover {
  color: var(--accent-hover);
}
.cost-factors__prompt-cta svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex-shrink: 0;
}

/* Aside card */
.cost-factors__aside-card {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: clamp(20px, 2.5vw, 28px);
}
.cost-factors__aside-label {
  display: block;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
}

/* Checks */
.cost-factors__checks {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 16px;
}
.cost-factors__checks li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-family: var(--font-body);
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--text-secondary);
}
.cost-factors__checks svg {
  width: 17px;
  height: 17px;
  stroke: var(--accent);
  fill: none;
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex-shrink: 0;
  margin-top: 1px;
}

/* Pills */
.cost-factors__pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}
.cost-factors__pill {
  display: inline-block;
  padding: 5px 14px;
  background: var(--accent-bg-solid);
  border: 1px solid var(--accent-border-solid);
  border-radius: 100px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  color: var(--accent);
}

/* List */
.cost-factors__list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}

/* Item */
.cost-factors__item {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-4);
  border-bottom: 1px solid var(--border);
  border-right: 1px solid var(--border);
}
.cost-factors__item:nth-child(2n) {
  border-right: none;
}
/* Last item (odd) spans full width */
.cost-factors__item:last-child:nth-child(odd) {
  grid-column: 1 / -1;
  border-right: none;
  border-bottom: none;
}
/* Last row for even count */
.cost-factors__item:nth-last-child(-n+2):nth-child(odd),
.cost-factors__item:nth-last-child(1):nth-child(even) {
  border-bottom: none;
}
/* Second-to-last when last is odd (row above full-span) */
.cost-factors__item:nth-last-child(2) {
  border-bottom: 1px solid var(--border);
}

/* Icon */
.cost-factors__icon {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 12px;
  flex-shrink: 0;
}
.cost-factors__icon svg {
  width: 22px;
  height: 22px;
  stroke: var(--accent);
  fill: none;
  stroke-width: 1.6;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* Body */
.cost-factors__title {
  font-family: var(--font-display);
  font-size: clamp(1.05rem, 0.95rem + 0.5vw, 1.25rem);
  font-weight: 700;
  line-height: 1.25;
  color: var(--text-primary);
  margin-bottom: 6px;
}
.cost-factors__body p {
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.7;
  color: var(--text-tertiary);
}

/* ── Scroll reveal ── */
.cost-factors__item {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.5s ease-out, transform 0.5s ease-out;
}
.cost-factors__item.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  .cost-factors__item {
    opacity: 1;
    transform: none;
  }
}

/* ── Responsive ── */
@media (max-width: 820px) {
  .cost-factors__header {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 720px) {
  .cost-factors__list {
    grid-template-columns: 1fr;
  }
  .cost-factors__item {
    border-right: none;
  }
  .cost-factors__item:last-child {
    border-bottom: none;
  }
  .cost-factors__item:last-child:nth-child(odd) {
    grid-column: auto;
  }
}

/* ============================================================
   FINAL CTA — KONTAKT
   ============================================================ */
.cennik-cta {
  position: relative;
  background: var(--dark-bg);
  padding: clamp(64px, 8vw, 120px) 0;
  overflow: hidden;
}
.cennik-cta::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 50% at 20% 50%, rgba(46,107,71,0.06) 0%, transparent 70%),
    radial-gradient(ellipse 40% 60% at 85% 30%, rgba(46,107,71,0.04) 0%, transparent 60%);
  pointer-events: none;
}
.cennik-cta__topline {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--accent-light), var(--accent), var(--accent-light), transparent);
  opacity: 0.45;
}

/* Grid */
.cennik-cta__grid {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 5vw, 80px);
  align-items: start;
}

/* ── Lewa kolumna ── */
.cennik-cta__eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent-light);
  margin-bottom: var(--space-2);
}
.cennik-cta__heading {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 1.2rem + 2.5vw, 2.75rem);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--text-inverse);
  margin-bottom: var(--space-2);
}
.cennik-cta__lead {
  font-family: var(--font-body);
  font-size: clamp(0.95rem, 0.85rem + 0.5vw, 1.1rem);
  line-height: 1.6;
  color: var(--dark-text-secondary);
  margin-bottom: var(--space-5);
}

/* Metody kontaktu */
.cennik-cta__methods {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.cennik-cta__method {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) 0;
  border-bottom: 1px solid var(--dark-border-subtle);
  transition: padding-left 0.25s ease;
}
.cennik-cta__method:first-child {
  padding-top: 0;
}
.cennik-cta__method:last-child {
  border-bottom: none;
}
a.cennik-cta__method:hover {
  padding-left: 6px;
}
.cennik-cta__method-icon {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(46,107,71,0.08);
  border: 1px solid rgba(46,107,71,0.15);
  border-radius: 10px;
  flex-shrink: 0;
}
.cennik-cta__method-icon svg {
  width: 18px;
  height: 18px;
  stroke: var(--accent-light);
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}
/* WhatsApp icon uses fill, not stroke */
.cennik-cta__method:nth-child(3) .cennik-cta__method-icon svg {
  fill: var(--accent-light);
  stroke: none;
  width: 20px;
  height: 20px;
}
.cennik-cta__method-text strong {
  display: block;
  font-family: var(--font-body);
  font-size: 14.5px;
  font-weight: 600;
  color: var(--dark-text);
}
.cennik-cta__method-text span {
  font-family: var(--font-body);
  font-size: 12.5px;
  color: var(--dark-text-muted);
}

/* ── Prawa kolumna: formularz ── */
.cennik-cta__form-wrap {
  background: var(--dark-bg-elevated);
  border: 1px solid var(--dark-border);
  border-radius: 16px;
  padding: clamp(28px, 3vw, 40px);
}
.cennik-cta__form-title {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 1rem + 1vw, 1.6rem);
  font-weight: 700;
  color: var(--dark-text);
  margin-bottom: 4px;
}
.cennik-cta__form-sub {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--dark-text-muted);
  margin-bottom: var(--space-3);
}

/* Fields */
.cennik-cta__field {
  margin-bottom: var(--space-2);
}
.cennik-cta__fields-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2);
}
.cennik-cta__label {
  display: block;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.03em;
  color: var(--dark-text-secondary);
  margin-bottom: 6px;
}
.cennik-cta__input {
  width: 100%;
  padding: 12px 16px;
  background: var(--dark-bg);
  border: 1px solid var(--dark-border);
  border-radius: 8px;
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--dark-text);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  outline: none;
}
.cennik-cta__input::placeholder {
  color: var(--dark-text-muted);
}
.cennik-cta__input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(46,107,71,0.15);
}
.cennik-cta__textarea {
  resize: vertical;
  min-height: 100px;
}

/* Consent */
.cennik-cta__consent {
  margin-bottom: var(--space-3);
}
.cennik-cta__checkbox-label {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-family: var(--font-body);
  font-size: 12px;
  line-height: 1.5;
  color: var(--dark-text-muted);
  cursor: pointer;
}
.cennik-cta__checkbox-label a {
  color: var(--accent-light);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.cennik-cta__checkbox-label a:hover {
  color: var(--dark-text);
}
.cennik-cta__checkbox {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  margin-top: 1px;
  accent-color: var(--accent);
  cursor: pointer;
}

/* Submit */
.cennik-cta__submit {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 14px 24px;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 10px;
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.3s ease;
}
.cennik-cta__submit svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.cennik-cta__submit:hover {
  background: var(--accent-hover);
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(46,107,71,0.3);
}

/* ── Scroll reveal ── */
.cennik-cta__content,
.cennik-cta__form-wrap {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}
.cennik-cta__content.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.cennik-cta__form-wrap.is-visible {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 0.1s;
}

@media (prefers-reduced-motion: reduce) {
  .cennik-cta__content,
  .cennik-cta__form-wrap {
    opacity: 1;
    transform: none;
  }
}

/* ── Responsive ── */
@media (max-width: 820px) {
  .cennik-cta__grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 480px) {
  .cennik-cta__fields-row {
    grid-template-columns: 1fr;
  }
}

/* ============================================================
   BAZA WIEDZY — Hero z wyszukiwarką
   ============================================================ */

.bw-hero {
  position: relative;
  background: var(--dark-bg);
  padding: clamp(90px, 10vw, 150px) 0 0;
  overflow: hidden;
  text-align: center;
}

/* Gradient overlays — depth */
.bw-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 70% 50% at 50% 0%, rgba(46,107,71,0.07) 0%, transparent 70%),
    radial-gradient(ellipse 60% 80% at 15% 50%, rgba(46,107,71,0.04) 0%, transparent 60%),
    radial-gradient(ellipse 60% 80% at 85% 50%, rgba(46,107,71,0.04) 0%, transparent 60%),
    radial-gradient(ellipse 80% 40% at 50% 100%, rgba(0,0,0,0.25) 0%, transparent 70%);
  pointer-events: none;
}

/* Subtle grid pattern overlay */
.bw-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(46,107,71,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(46,107,71,0.03) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse 80% 70% at 50% 40%, black 0%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse 80% 70% at 50% 40%, black 0%, transparent 70%);
  pointer-events: none;
}

/* Accent top line */
.bw-hero__topline {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--accent-light), var(--accent), var(--accent-light), transparent);
  opacity: 0.5;
}

/* Content wrapper */
.bw-hero__content {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 760px;
  margin: 0 auto;
}

/* Eyebrow badge */
.bw-hero__eyebrow {
  margin-bottom: var(--space-3);
}

.bw-hero__eyebrow span {
  display: inline-block;
  padding: 5px 16px;
  border-radius: 100px;
  background: rgba(46,107,71,0.08);
  border: 1px solid rgba(46,107,71,0.18);
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--accent-light);
}

/* H1 */
.bw-hero__heading {
  font-family: var(--font-display);
  font-size: clamp(2rem, 1.4rem + 3vw, 3.25rem);
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--text-inverse);
  margin-bottom: var(--space-2);
}

.bw-hero__heading em {
  font-style: normal;
  color: var(--accent-light);
}

/* Lead */
.bw-hero__lead {
  font-family: var(--font-body);
  font-size: clamp(1rem, 0.9rem + 0.5vw, 1.15rem);
  font-weight: 400;
  line-height: 1.6;
  color: var(--dark-text-secondary);
  max-width: 540px;
  margin-bottom: var(--space-5);
}

/* Article count */
.bw-hero__count {
  display: inline-block;
  margin-left: 4px;
  padding: 2px 10px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.5px;
  color: var(--accent-light);
  background: rgba(46,107,71,0.1);
  border-radius: 100px;
  vertical-align: middle;
  position: relative;
  top: -1px;
}

/* ── Search bar ── */
.bw-hero__search {
  position: relative;
  width: 100%;
  max-width: 600px;
  margin-bottom: var(--space-5);
}

.bw-search {
  position: relative;
  display: flex;
  align-items: center;
}

.bw-search__icon {
  position: absolute;
  left: 20px;
  width: 20px;
  height: 20px;
  color: var(--dark-text-muted);
  pointer-events: none;
  transition: color 0.25s ease;
}

.bw-search__input {
  width: 100%;
  padding: 16px 56px 16px 52px;
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 400;
  color: var(--dark-text);
  background: var(--dark-bg-elevated);
  border: 1px solid var(--dark-border);
  border-radius: 12px;
  outline: none;
  transition: border-color 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
  -webkit-appearance: none;
}

.bw-search__input::placeholder {
  color: var(--dark-text-muted);
  font-weight: 400;
}

.bw-search__input:hover {
  border-color: var(--dark-border);
  background: rgba(26,61,43,0.8);
}

.bw-search__input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(46,107,71,0.15), 0 8px 32px rgba(0,0,0,0.2);
  background: rgba(26,61,43,0.9);
}

.bw-search__input:focus ~ .bw-search__icon {
  color: var(--accent-light);
}

.bw-search__input:focus ~ .bw-search__kbd {
  opacity: 0;
}

/* Idle border pulse — draws attention before interaction */
@keyframes bwSearchPulse {
  0%, 100% { border-color: var(--dark-border); box-shadow: none; }
  50% { border-color: rgba(46,107,71,0.4); box-shadow: 0 0 0 3px rgba(46,107,71,0.06); }
}

.bw-search__input.is-idle {
  animation: bwSearchPulse 3s ease-in-out infinite;
}

.bw-search__input:focus,
.bw-search__input:not(:placeholder-shown) {
  animation: none;
}

/* Keyboard shortcut hint */
.bw-search__kbd {
  position: absolute;
  right: 16px;
  padding: 3px 8px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  color: var(--dark-text-muted);
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--dark-border);
  border-radius: 6px;
  pointer-events: none;
  transition: opacity 0.2s ease;
  line-height: 1.4;
}

/* Remove webkit search cancel button */
.bw-search__input::-webkit-search-cancel-button,
.bw-search__input::-webkit-search-decoration {
  -webkit-appearance: none;
  appearance: none;
}

/* ── Popular tags ── */
.bw-search__tags {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
  justify-content: center;
}

.bw-search__tags-label {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  color: var(--dark-text-muted);
  margin-right: 2px;
}

.bw-search__tag {
  display: inline-block;
  padding: 4px 12px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  color: var(--dark-text-secondary);
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--dark-border-subtle);
  border-radius: 100px;
  text-decoration: none;
  transition: all 0.25s ease;
  white-space: nowrap;
}

.bw-search__tag:hover {
  color: var(--accent-light);
  background: rgba(46,107,71,0.1);
  border-color: rgba(46,107,71,0.25);
}

/* ── Live search dropdown ── */
.bw-search__dropdown {
  position: fixed;
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow: 0 12px 40px rgba(0,0,0,0.12), 0 4px 12px rgba(0,0,0,0.06);
  overflow: hidden;
  overflow-y: auto;
  max-height: 420px;
  z-index: 9999;
  animation: bwDropdownIn 0.2s ease;
}

@keyframes bwDropdownIn {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

.bw-search__dropdown[hidden] {
  display: none;
}

.bw-search__dropdown-item {
  display: block;
  padding: 14px 20px;
  text-decoration: none;
  border-bottom: 1px solid rgba(0,0,0,0.04);
  transition: background 0.15s ease;
}

.bw-search__dropdown-item:hover,
.bw-search__dropdown-item.is-highlighted {
  background: rgba(46,107,71,0.05);
}

.bw-search__dropdown-title {
  font-family: var(--font-body);
  font-size: 14.5px;
  font-weight: 500;
  color: var(--text-primary);
  line-height: 1.4;
  margin-bottom: 4px;
}

.bw-search__dropdown-title mark {
  background: rgba(46,107,71,0.15);
  color: var(--accent);
  border-radius: 2px;
  padding: 0 1px;
}

.bw-search__dropdown-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12.5px;
  color: var(--text-muted);
}

.bw-search__dropdown-cat {
  font-weight: 600;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 2px 8px;
  border-radius: 100px;
  background: rgba(0,0,0,0.05);
}

.bw-search__dropdown-all {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 20px;
  font-family: var(--font-body);
  font-size: 13.5px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  background: rgba(46,107,71,0.04);
  transition: background 0.15s ease;
}

.bw-search__dropdown-all:hover {
  background: rgba(46,107,71,0.08);
}

.bw-search__dropdown-all svg {
  width: 16px;
  height: 16px;
}

.bw-search__dropdown-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 24px 20px;
  color: var(--text-muted);
  font-size: 14px;
}

.bw-search__dropdown-empty svg {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  opacity: 0.5;
}

/* ── Trust bar ── */
.bw-hero__trust {
  display: flex;
  align-items: center;
  gap: 0;
  flex-wrap: wrap;
  justify-content: center;
}

.bw-hero__trust-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 400;
  color: var(--dark-text-muted);
  white-space: nowrap;
}

.bw-hero__trust-item svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  color: var(--accent-light);
  opacity: 0.7;
}

.bw-hero__trust-item strong {
  font-weight: 600;
  color: var(--dark-text-secondary);
}

.bw-hero__trust-sep {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: var(--dark-text-muted);
  opacity: 0.4;
  margin: 0 14px;
  flex-shrink: 0;
}

/* ── Entrance animations ── */
@keyframes bwFadeInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.bw-anim {
  opacity: 0;
  animation: bwFadeInUp 0.6s ease forwards;
}

.bw-anim--1 { animation-delay: 0.05s; }
.bw-anim--2 { animation-delay: 0.15s; }
.bw-anim--3 { animation-delay: 0.25s; }
.bw-anim--4 { animation-delay: 0.35s; }
.bw-anim--5 { animation-delay: 0.45s; }
.bw-anim--6 { animation-delay: 0.55s; }

/* ── Micro-CTA ── */
.bw-hero__micro-cta {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: var(--space-4);
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--dark-text-muted);
}

.bw-hero__micro-cta-link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: var(--accent-light);
  text-decoration: none;
  font-weight: 500;
  transition: color 0.25s ease, gap 0.25s ease;
}

.bw-hero__micro-cta-link:hover {
  color: var(--accent-champagne);
  gap: 8px;
}

.bw-hero__micro-cta-link svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}

@media (prefers-reduced-motion: reduce) {
  .bw-anim {
    opacity: 1;
    animation: none;
    transform: none;
  }

  .bw-search__input.is-idle {
    animation: none;
  }
}

/* ── Responsive ── */
@media (max-width: 600px) {
  .bw-hero {
    padding: 100px 0 0;
  }

  .bw-hero__lead {
    margin-bottom: var(--space-4);
  }

  .bw-hero__search {
    margin-bottom: var(--space-4);
  }

  .bw-search__input {
    padding: 14px 48px 14px 46px;
    font-size: 14px;
    border-radius: 10px;
  }

  .bw-search__icon {
    left: 16px;
    width: 18px;
    height: 18px;
  }

  .bw-search__kbd {
    display: none;
  }

  .bw-hero__trust {
    flex-direction: column;
    gap: 8px;
  }

  .bw-hero__trust-sep {
    display: none;
  }

  .bw-search__tags {
    gap: 6px;
  }

  .bw-search__tag {
    font-size: 11px;
    padding: 3px 10px;
  }

  .bw-hero__micro-cta {
    flex-direction: column;
    gap: 2px;
    text-align: center;
  }
}

/* ── Breaking News Ticker (bw-hero bottom strip) ── */
.bw-ticker {
  display: flex;
  align-items: stretch;
  background: rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-top: 1px solid rgba(74, 154, 106, 0.15);
  overflow: hidden;
  margin-top: clamp(32px, 4vw, 56px);
  opacity: 0;
  animation: bwFadeInUp 0.5s ease 1.2s forwards;
}

@keyframes bwFadeInUp {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

.bw-ticker__label {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 20px;
  background: var(--accent);
  color: #fff;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  white-space: nowrap;
  flex-shrink: 0;
  position: relative;
  z-index: 1;
}

.bw-ticker__label::after {
  content: '';
  position: absolute;
  right: -12px;
  top: 0;
  bottom: 0;
  width: 24px;
  background: var(--accent);
  clip-path: polygon(0 0, 50% 0, 100% 100%, 0 100%);
}

.bw-ticker__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #ef4444;
  flex-shrink: 0;
  animation: bwTickerPulse 2s ease-in-out infinite;
}

@keyframes bwTickerPulse {
  0%, 100% { opacity: 1; box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.5); }
  50%      { opacity: 0.6; box-shadow: 0 0 0 4px rgba(239, 68, 68, 0); }
}

.bw-ticker__track {
  display: flex;
  overflow: hidden;
  flex: 1;
  mask-image: linear-gradient(90deg, transparent, #000 40px, #000 calc(100% - 40px), transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 40px, #000 calc(100% - 40px), transparent);
  padding-left: 16px;
}

.bw-ticker__scroll {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  animation: bwTickerSlide var(--bw-ticker-duration, 35s) linear infinite;
}

.bw-ticker:hover .bw-ticker__scroll {
  animation-play-state: paused;
}

@keyframes bwTickerSlide {
  from { transform: translateX(0); }
  to   { transform: translateX(-100%); }
}

.bw-ticker__item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 0;
  text-decoration: none;
  white-space: nowrap;
  transition: opacity 0.2s;
}

.bw-ticker__item:hover {
  opacity: 0.7;
}

.bw-ticker__cat {
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--accent-light);
  background: rgba(46, 107, 71, 0.15);
  border: 1px solid rgba(46, 107, 71, 0.25);
  padding: 2px 8px;
  border-radius: 3px;
  flex-shrink: 0;
}

.bw-ticker__title {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--dark-text-secondary);
  max-width: 360px;
  overflow: hidden;
  text-overflow: ellipsis;
}

.bw-ticker__item:hover .bw-ticker__title {
  color: #fff;
}

.bw-ticker__sep {
  color: var(--dark-text-muted);
  margin: 0 16px;
  font-size: 8px;
  opacity: 0.4;
}

@media (max-width: 640px) {
  .bw-ticker__label {
    padding: 10px 14px;
    font-size: 10px;
  }
  .bw-ticker__label::after {
    right: -8px;
    width: 16px;
  }
  .bw-ticker__title {
    font-size: 12px;
    max-width: 240px;
  }
  .bw-ticker__cat {
    display: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  .bw-ticker {
    animation: none !important;
    opacity: 1 !important;
  }
  .bw-ticker__scroll {
    animation: none !important;
  }
  .bw-ticker__track {
    overflow-x: auto;
  }
}

/* ============================================================
   BAZA WIEDZY — Sekcja 2: Filtrowanie po kategoriach
   ============================================================ */

.bw-filters {
  background: var(--bg-primary);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--border);
}

/* ── Bar: categories + sorting ── */
.bw-filters__bar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
}

/* ── Desktop: pill buttons ── */
.bw-filters__pills {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-start;
  flex: 1;
  min-width: 0;
}

.bw-filters__pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 20px;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  color: var(--text-secondary);
  background: var(--bg-secondary);
  border: 1px solid rgba(0,0,0,0.06);
  border-radius: 100px;
  text-decoration: none;
  transition: all 0.2s ease;
  white-space: nowrap;
}

.bw-filters__pill:hover {
  border-color: rgba(0,0,0,0.12);
  color: var(--text-primary);
  background: rgba(0,0,0,0.04);
}

.bw-filters__pill.is-active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}

.bw-filters__pill.is-active .bw-filters__pill-count {
  background: rgba(255,255,255,0.2);
  color: #fff;
}

.bw-filters__pill-count {
  font-size: 12px;
  font-weight: 600;
  background: rgba(0,0,0,0.06);
  color: var(--text-muted);
  padding: 2px 8px;
  border-radius: 100px;
  line-height: 1.4;
}

/* ── Hidden pills (collapsed state) ── */
.bw-filters__pill--hidden {
  display: none;
}

.bw-filters__pills.is-expanded .bw-filters__pill--hidden {
  display: inline-flex;
}

/* ── Expand / collapse button ── */
.bw-filters__expand {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 20px;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  color: var(--accent);
  background: transparent;
  border: 1px dashed rgba(46,107,71,0.3);
  border-radius: 100px;
  cursor: pointer;
  transition: all 0.2s ease;
  white-space: nowrap;
}

.bw-filters__expand:hover {
  border-color: var(--accent);
  background: rgba(46,107,71,0.04);
}

.bw-filters__expand-icon {
  width: 16px;
  height: 16px;
  transition: transform 0.25s ease;
}

.bw-filters__expand[aria-expanded="true"] .bw-filters__expand-icon {
  transform: rotate(180deg);
}

.bw-filters__expand-less {
  display: none;
}

.bw-filters__expand[aria-expanded="true"] .bw-filters__expand-more {
  display: none;
}

.bw-filters__expand[aria-expanded="true"] .bw-filters__expand-less {
  display: inline;
}

.bw-filters__expand-count {
  font-size: 12px;
  opacity: 0.7;
}

/* ── Sorting dropdown ── */
.bw-sort-dropdown {
  position: relative;
  flex-shrink: 0;
}

.bw-sort-dropdown__trigger {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  color: var(--text-secondary);
  background: var(--bg-secondary);
  border: 1px solid rgba(0,0,0,0.06);
  border-radius: 100px;
  cursor: pointer;
  transition: all 0.2s ease;
  white-space: nowrap;
}

.bw-sort-dropdown__trigger:hover {
  border-color: rgba(0,0,0,0.12);
  color: var(--text-primary);
}

.bw-sort-dropdown__trigger[aria-expanded="true"] {
  border-color: var(--accent);
  color: var(--text-primary);
  box-shadow: 0 0 0 3px rgba(46,107,71,0.08);
}

.bw-sort-dropdown__icon {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

.bw-sort-dropdown__arrow {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  transition: transform 0.2s ease;
}

.bw-sort-dropdown__trigger[aria-expanded="true"] .bw-sort-dropdown__arrow {
  transform: rotate(180deg);
}

.bw-sort-dropdown__menu {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 180px;
  background: var(--bg-primary);
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(13,13,13,0.1), 0 2px 8px rgba(13,13,13,0.06);
  padding: 6px;
  z-index: 100;
  opacity: 0;
  transform: translateY(-4px);
  transition: opacity 0.15s ease, transform 0.15s ease;
}

.bw-sort-dropdown__menu:not([hidden]) {
  opacity: 1;
  transform: translateY(0);
}

.bw-sort-dropdown__item {
  display: flex;
  align-items: center;
  width: 100%;
  padding: 10px 14px;
  font-family: var(--font-body);
  font-size: 13.5px;
  font-weight: 500;
  color: var(--text-secondary);
  background: none;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  text-align: left;
  transition: all 0.15s ease;
}

.bw-sort-dropdown__item:hover {
  background: rgba(0,0,0,0.04);
  color: var(--text-primary);
}

.bw-sort-dropdown__item.is-active {
  color: var(--accent);
  font-weight: 600;
  background: rgba(46,107,71,0.06);
}

/* ── Mobile: select dropdown (hidden on desktop) ── */
.bw-filters__select-wrap {
  position: relative;
  display: none;
  align-items: center;
  background: var(--bg-secondary);
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,0.06);
  padding: 0 16px;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.bw-filters__select-wrap:hover {
  border-color: rgba(0,0,0,0.12);
}

.bw-filters__select-wrap:focus-within {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(46,107,71,0.1);
}

/* Reset text-align for container */
.bw-filters .container {
  text-align: left;
}

/* ── Left icon ── */
.bw-filters__select-icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  color: var(--text-muted);
  pointer-events: none;
}

/* ── Native select ── */
.bw-filters__select {
  appearance: none;
  -webkit-appearance: none;
  background: none;
  border: none;
  outline: none;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  color: var(--text-primary);
  padding: 12px 32px 12px 10px;
  cursor: pointer;
  min-width: 200px;
}

.bw-filters__select option {
  font-size: 14px;
  padding: 8px;
}

/* ── Right arrow ── */
.bw-filters__select-arrow {
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  color: var(--text-muted);
  pointer-events: none;
  transition: color 0.2s ease;
}

.bw-filters__select-wrap:hover .bw-filters__select-arrow {
  color: var(--text-secondary);
}

/* ── Responsive ── */
@media (max-width: 768px) {
  .bw-filters {
    padding: var(--space-2) 0;
  }

  .bw-filters__bar {
    flex-direction: column;
    gap: 10px;
  }

  /* Hide pills on mobile */
  .bw-filters__pills {
    display: none;
  }

  /* Show selects on mobile */
  .bw-filters__select-wrap {
    display: flex;
    width: 100%;
    border-radius: 10px;
  }

  .bw-filters .container {
    text-align: left;
  }

  .bw-filters__select {
    width: 100%;
    font-size: 13.5px;
    padding: 11px 32px 11px 10px;
  }
}

/* ============================================================
   BAZA WIEDZY — Sekcja 3+4: Grid artykułów + Sidebar
   ============================================================ */

.bw-listing {
  background: var(--bg-primary);
  padding: var(--space-7) 0 var(--space-10);
}

/* ── Layout: grid + sidebar ── */
.bw-listing__layout {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: var(--space-7);
  align-items: start;
}

/* ── Article grid ── */
.bw-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}

/* Emergency CTA spans full width of grid */
.bw-emergency-cta {
  grid-column: 1 / -1;
}

/* ── Article card ── */
.bw-card {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}

.bw-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: var(--accent-border-solid);
}

/* Card image */
.bw-card__image-link {
  display: block;
  overflow: hidden;
  aspect-ratio: 16 / 9;
  background: var(--bg-secondary);
}

.bw-card__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.bw-card:hover .bw-card__image {
  transform: scale(1.04);
}

/* Card body */
.bw-card__body {
  padding: var(--space-3);
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: var(--space-1);
}

/* Meta top */
.bw-card__meta-top {
  margin-bottom: 2px;
}

/* Category badge */
.bw-card__badge {
  display: inline-block;
  padding: 3px 10px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  border-radius: 100px;
  color: var(--text-tertiary);
  background: var(--bg-secondary);
}

[class*="bw-card__badge--"][class*="kryminalne"] {
  color: var(--accent);
  background: var(--accent-bg-solid);
}

[class*="bw-card__badge--"][class*="gospodarcze"] {
  color: #6B5B3E;
  background: var(--champagne-bg-solid);
}

[class*="bw-card__badge--"][class*="skarbowe"] {
  color: #4A6B8A;
  background: #EDF3F8;
}

[class*="bw-card__badge--"][class*="wykonawcze"] {
  color: var(--text-tertiary);
  background: var(--bg-secondary);
}

[class*="bw-card__badge--"][class*="pilne"] {
  color: var(--emergency-text);
  background: var(--emergency-bg);
}

/* Title */
.bw-card__title {
  font-family: var(--font-display);
  font-size: clamp(1.15rem, 1rem + 0.5vw, 1.35rem);
  font-weight: 600;
  line-height: 1.25;
  letter-spacing: -0.01em;
}

.bw-card__title a {
  color: var(--text-primary);
  text-decoration: none;
  transition: color 0.2s ease;
}

.bw-card__title a:hover {
  color: var(--accent);
}

/* Excerpt */
.bw-card__excerpt {
  font-family: var(--font-body);
  font-size: 13.5px;
  font-weight: 400;
  line-height: 1.6;
  color: var(--text-tertiary);
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Meta bottom */
.bw-card__meta-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-1);
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--text-muted);
  margin-top: auto;
  padding-top: var(--space-1);
}

.bw-card__meta-left {
  display: flex;
  align-items: center;
  gap: 0;
}

/* Read more link */
.bw-card__read-more {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  white-space: nowrap;
  transition: gap 0.25s ease;
}

.bw-card__read-more svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  transition: transform 0.25s ease;
}

.bw-card__read-more:hover {
  gap: 6px;
}

.bw-card__read-more:hover svg {
  transform: translateX(2px);
}

.bw-card__meta-sep {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: var(--text-muted);
  opacity: 0.4;
  margin: 0 8px;
  flex-shrink: 0;
}

/* ── Card filter animation ── */
.bw-card.is-hidden {
  display: none;
}

/* ── Scroll reveal ── */
.bw-reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s cubic-bezier(0.16, 1, 0.3, 1), transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.bw-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ── No results ── */
.bw-grid__empty {
  text-align: center;
  padding: var(--space-8) var(--space-4);
  color: var(--text-muted);
  font-family: var(--font-body);
  font-size: 15px;
}

.bw-grid__empty svg {
  width: 48px;
  height: 48px;
  margin-bottom: var(--space-2);
  opacity: 0.3;
}

/* ============================================================
   BAZA WIEDZY — Emergency CTA Strip (between articles)
   ============================================================ */

.bw-emergency-cta {
  margin: var(--space-2) 0;
  border-radius: 14px;
  overflow: hidden;
  background: var(--emergency-bg);
  position: relative;
}

/* Subtle shimmer */
.bw-emergency-cta::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, transparent 40%, rgba(74,154,106,0.04) 50%, transparent 60%);
  background-size: 200% 200%;
  animation: bwEmShimmer 6s ease-in-out infinite;
  pointer-events: none;
}

@keyframes bwEmShimmer {
  0%, 100% { background-position: 200% 200%; }
  50% { background-position: 0% 0%; }
}

.bw-emergency-cta__inner {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
}

.bw-emergency-cta__content {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

/* Pulsing dot */
.bw-emergency-cta__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--emergency-accent);
  flex-shrink: 0;
  position: relative;
}

.bw-emergency-cta__dot::after {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  background: var(--emergency-accent);
  animation: bwEmDotPulse 2s ease-in-out infinite;
  opacity: 0;
}

@keyframes bwEmDotPulse {
  0%, 100% { transform: scale(0.8); opacity: 0; }
  50% { transform: scale(2); opacity: 0.3; }
}

.bw-emergency-cta__text {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--emergency-text);
  line-height: 1.4;
}

.bw-emergency-cta__text strong {
  font-weight: 600;
  color: #fff;
}

.bw-emergency-cta__actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.bw-emergency-cta__btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--emergency-bg);
  background: var(--emergency-accent);
  border-radius: 8px;
  text-decoration: none;
  transition: all 0.25s ease;
  white-space: nowrap;
}

.bw-emergency-cta__btn svg {
  width: 15px;
  height: 15px;
}

.bw-emergency-cta__btn:hover {
  background: var(--accent-light);
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(74,154,106,0.3);
}

.bw-emergency-cta__wa {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 8px;
  background: rgba(255,255,255,0.08);
  color: #25D366;
  text-decoration: none;
  transition: background 0.25s ease;
}

.bw-emergency-cta__wa svg {
  width: 18px;
  height: 18px;
}

.bw-emergency-cta__wa:hover {
  background: rgba(255,255,255,0.14);
}

/* ============================================================
   BAZA WIEDZY — Pagination
   ============================================================ */

.bw-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  margin-top: var(--space-7);
  padding-top: var(--space-5);
  border-top: 1px solid var(--border);
}

.bw-pagination__btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 16px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-secondary);
  text-decoration: none;
  border: 1px solid var(--border);
  border-radius: 8px;
  transition: all 0.25s ease;
}

.bw-pagination__btn svg {
  width: 16px;
  height: 16px;
}

.bw-pagination__btn:hover:not(.is-disabled) {
  color: var(--text-primary);
  border-color: var(--accent-border-solid);
  background: var(--bg-elevated);
  box-shadow: var(--shadow-sm);
}

.bw-pagination__btn.is-disabled {
  opacity: 0.35;
  pointer-events: none;
}

.bw-pagination__pages {
  display: flex;
  align-items: center;
  gap: 4px;
}

.bw-pagination__page {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-secondary);
  text-decoration: none;
  border-radius: 8px;
  transition: all 0.25s ease;
}

.bw-pagination__page:hover {
  background: var(--bg-secondary);
  color: var(--text-primary);
}

.bw-pagination__page.is-active {
  background: var(--accent);
  color: #fff;
  font-weight: 600;
  box-shadow: 0 2px 8px rgba(46,107,71,0.18);
}

.bw-pagination__ellipsis {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text-muted);
}

/* ============================================================
   BAZA WIEDZY — Sidebar
   ============================================================ */

.bw-sidebar__inner {
  position: sticky;
  top: 80px;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

/* ── CTA Box ── */
.bw-sidebar__cta {
  background: var(--dark-bg);
  border-radius: 16px;
  padding: var(--space-4);
  text-align: center;
  position: relative;
  overflow: hidden;
}

/* Background glow */
.bw-sidebar__cta::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 70% 50% at 50% 0%, rgba(46,107,71,0.1) 0%, transparent 60%),
    radial-gradient(ellipse 60% 60% at 50% 100%, rgba(0,0,0,0.2) 0%, transparent 60%);
  pointer-events: none;
}

.bw-sidebar__cta > * {
  position: relative;
  z-index: 1;
}

.bw-sidebar__cta-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent-light);
  margin: 0 auto var(--space-2);
  position: relative;
}

.bw-sidebar__cta-dot::after {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  background: var(--accent-light);
  opacity: 0;
  animation: bwEmDotPulse 2s ease-in-out infinite;
}

.bw-sidebar__cta-heading {
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.3;
  color: var(--dark-text);
  margin-bottom: var(--space-3);
}

.bw-sidebar__cta-heading strong {
  color: var(--accent-light);
}

.bw-sidebar__cta-phone {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 12px;
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 600;
  color: var(--dark-bg);
  background: var(--accent-light);
  border-radius: 10px;
  text-decoration: none;
  transition: all 0.25s ease;
  margin-bottom: var(--space-1);
}

.bw-sidebar__cta-phone svg {
  width: 18px;
  height: 18px;
}

.bw-sidebar__cta-phone:hover {
  background: #5AB87A;
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(74,154,106,0.3);
}

.bw-sidebar__cta-wa {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 10px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: #25D366;
  background: rgba(37,211,102,0.08);
  border-radius: 10px;
  text-decoration: none;
  transition: background 0.25s ease;
  margin-bottom: var(--space-2);
}

.bw-sidebar__cta-wa svg {
  width: 16px;
  height: 16px;
}

.bw-sidebar__cta-wa:hover {
  background: rgba(37,211,102,0.15);
}

.bw-sidebar__cta-hours {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 500;
  color: var(--dark-text-muted);
  letter-spacing: 0.3px;
}

/* ── Sidebar sections ── */
.bw-sidebar__section {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: var(--space-3);
}

.bw-sidebar__heading {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: var(--space-2);
  padding-bottom: var(--space-1);
  border-bottom: 1px solid var(--border);
}

/* Popular articles */
.bw-sidebar__popular {
  list-style: none;
  counter-reset: popular;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.bw-sidebar__popular li {
  counter-increment: popular;
  border-bottom: 1px solid var(--border);
}

.bw-sidebar__popular li:last-child {
  border-bottom: none;
}

.bw-sidebar__popular li a {
  display: flex;
  align-items: baseline;
  gap: 10px;
  padding: 10px 0;
  font-family: var(--font-body);
  font-size: 13.5px;
  font-weight: 400;
  line-height: 1.4;
  color: var(--text-secondary);
  text-decoration: none;
  transition: color 0.2s ease;
}

.bw-sidebar__popular li a::before {
  content: counter(popular);
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  font-size: 11px;
  font-weight: 700;
  color: var(--accent);
  background: var(--accent-bg-solid);
  border-radius: 6px;
}

.bw-sidebar__popular li a:hover {
  color: var(--accent);
}

/* Categories */
.bw-sidebar__categories {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.bw-sidebar__categories li {
  border-bottom: 1px solid var(--border);
}

.bw-sidebar__categories li:last-child {
  border-bottom: none;
}

.bw-sidebar__categories li a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 0;
  font-family: var(--font-body);
  font-size: 13.5px;
  font-weight: 400;
  color: var(--text-secondary);
  text-decoration: none;
  transition: color 0.2s ease;
}

.bw-sidebar__categories li a:hover {
  color: var(--accent);
}

.bw-sidebar__cat-count {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-muted);
  background: var(--bg-secondary);
  padding: 2px 8px;
  border-radius: 100px;
}

/* Tag cloud */
.bw-sidebar__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.bw-sidebar__tag {
  display: inline-block;
  padding: 4px 11px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  color: var(--text-tertiary);
  background: var(--bg-secondary);
  border: 1px solid transparent;
  border-radius: 100px;
  text-decoration: none;
  transition: all 0.2s ease;
}

.bw-sidebar__tag:hover {
  color: var(--accent);
  background: var(--accent-bg-solid);
  border-color: var(--accent-border-solid);
}

/* ============================================================
   BAZA WIEDZY — Responsive (grid + sidebar + emergency)
   ============================================================ */

@media (max-width: 1080px) {
  .bw-listing__layout {
    grid-template-columns: 1fr 280px;
    gap: var(--space-5);
  }
}

@media (max-width: 900px) {
  .bw-listing__layout {
    grid-template-columns: 1fr;
  }

  .bw-sidebar {
    order: -1;
  }

  .bw-sidebar__inner {
    position: static;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-3);
  }

  .bw-sidebar__cta {
    grid-column: 1 / -1;
  }
}

@media (max-width: 700px) {
  .bw-grid {
    grid-template-columns: 1fr;
  }

  .bw-sidebar__inner {
    grid-template-columns: 1fr;
  }

  .bw-emergency-cta__inner {
    flex-direction: column;
    text-align: center;
    gap: var(--space-2);
  }

  .bw-emergency-cta__content {
    flex-direction: column;
    gap: var(--space-1);
  }

  .bw-pagination__btn span {
    display: none;
  }

  .bw-pagination__btn {
    padding: 9px 12px;
  }
}

@media (max-width: 480px) {
  .bw-listing {
    padding: var(--space-5) 0 var(--space-7);
  }

  .bw-card__body {
    padding: var(--space-2);
  }

  .bw-card__title {
    font-size: 1.05rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .bw-reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .bw-emergency-cta::before {
    animation: none;
  }

  .bw-emergency-cta__dot::after {
    animation: none;
  }

  .bw-sidebar__cta-dot::after {
    animation: none;
  }
}


/* ============================================================
   O KANCELARII — Hero Section
   ============================================================ */

.oka-hero {
  position: relative;
  background: var(--dark-bg);
  min-height: 90vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(96px, 12vw, 200px) 0 clamp(48px, 5vw, 72px);
  overflow: hidden;
}

/* Gradient overlays for depth */
.oka-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 20% 40%, rgba(46,107,71,0.05) 0%, transparent 70%),
    radial-gradient(ellipse 50% 80% at 85% 20%, rgba(46,107,71,0.03) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 50% 100%, rgba(0,0,0,0.3) 0%, transparent 70%);
  pointer-events: none;
}

/* Accent top line */
.oka-hero__topline {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--accent-light), var(--accent), var(--accent-light), transparent);
  opacity: 0.5;
}

/* Grid: 2 columns — text dominant */
.oka-hero__grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: clamp(32px, 3.5vw, 64px);
  align-items: stretch;
}

/* Text column */
.oka-hero__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0;
}

/* Eyebrow badge */
.oka-hero__badge {
  margin-bottom: var(--space-2);
}
.oka-hero__badge span {
  display: inline-block;
  padding: 5px 14px;
  border-radius: 100px;
  background: rgba(46,107,71,0.08);
  border: 1px solid rgba(46,107,71,0.18);
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--accent-light);
}

/* H1 */
.oka-hero__heading {
  font-family: var(--font-display);
  font-size: clamp(2rem, 1.4rem + 3vw, 3.25rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--text-inverse);
  margin-bottom: var(--space-2);
}
.oka-hero__heading em {
  font-family: var(--font-display);
  font-style: normal;
  font-weight: 500;
  color: var(--accent-light);
}

/* Lead — with accent left border for editorial feel */
.oka-hero__lead {
  font-family: var(--font-body);
  font-size: clamp(1.05rem, 0.95rem + 0.5vw, 1.25rem);
  font-weight: 400;
  line-height: 1.6;
  color: var(--dark-text-secondary);
  max-width: 560px;
  margin-bottom: var(--space-3);
  padding-left: var(--space-2);
  border-left: 2px solid var(--dark-border);
}

/* CTA row */
.oka-hero__ctas {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}
.oka-hero__ctas .btn-ghost-dark {
  padding: 12px 28px;
  font-size: 14px;
}
.oka-hero__ctas .btn-ghost-dark svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
}
.oka-hero__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  color: var(--dark-text-muted);
  text-decoration: none;
  transition: color 0.25s ease;
}
.oka-hero__link svg {
  width: 16px;
  height: 16px;
  transition: transform 0.25s ease;
}
.oka-hero__link:hover {
  color: var(--accent-light);
}
.oka-hero__link:hover svg {
  transform: translateX(3px);
}

/* Trust strip */
.oka-hero__trust {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}
.oka-hero__trust-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--dark-text-muted);
}
.oka-hero__trust-item svg {
  width: 14px;
  height: 14px;
  stroke: var(--accent-light);
  fill: none;
  flex-shrink: 0;
}

/* Photo column */
.oka-hero__photo {
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  min-height: 400px;
}
.oka-hero__photo img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}
/* Bottom gradient vignette */
.oka-hero__photo::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 40%;
  background: linear-gradient(to top, rgba(15,45,31,0.45) 0%, transparent 100%);
  pointer-events: none;
}

/* Floating award badge */
.oka-hero__award {
  position: absolute;
  top: 16px;
  right: 16px;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px 7px 10px;
  border-radius: 100px;
  background: rgba(15,45,31,0.65);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(46,107,71,0.2);
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  color: var(--dark-text);
  letter-spacing: 0.02em;
}
.oka-hero__award svg {
  width: 14px;
  height: 14px;
  stroke: var(--accent-light);
  fill: none;
  flex-shrink: 0;
}

/* Motto overlay on photo bottom */
.oka-hero__motto {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 2;
  padding: 28px 24px 20px;
  background: linear-gradient(to top, rgba(13,13,13,0.75) 0%, rgba(13,13,13,0.35) 65%, transparent 100%);
}
.oka-hero__motto p {
  font-family: var(--font-display);
  font-size: clamp(0.95rem, 0.85rem + 0.4vw, 1.1rem);
  font-style: italic;
  font-weight: 400;
  line-height: 1.4;
  color: rgba(255,255,255,0.85);
  letter-spacing: 0.01em;
  margin-bottom: 4px;
}
.oka-hero__motto cite {
  font-family: var(--font-body);
  font-size: 11px;
  font-style: normal;
  font-weight: 600;
  color: var(--dark-text-muted);
  letter-spacing: 0.5px;
}

/* ── OKA Hero entrance animations ── */
.oka-anim {
  opacity: 0;
  animation: heroFadeInUp 0.6s ease both;
}
.oka-anim--1 { animation-delay: 0.05s; }
.oka-anim--2 { animation-delay: 0.15s; }
.oka-anim--3 { animation-delay: 0.25s; }
.oka-anim--4 { animation-delay: 0.35s; }
.oka-anim--5 { animation-delay: 0.45s; }
.oka-anim--6 { animation-delay: 0.55s; }
.oka-anim--photo { animation-delay: 0.2s; }

/* ── OKA Hero responsive ── */

/* Tablet (601–960px) */
@media (max-width: 960px) {
  .oka-hero__grid {
    grid-template-columns: 1fr;
    gap: var(--space-3);
  }
  .oka-hero__photo {
    order: 2;
    height: 360px;
    min-height: auto;
    border-radius: 14px;
  }
  .oka-hero__content {
    order: 1;
  }
}

/* Mobile (≤600px) */
@media (max-width: 600px) {
  .oka-hero {
    min-height: auto;
    padding: 80px 0 0;
  }
  .oka-hero__heading {
    margin-bottom: var(--space-2);
  }
  .oka-hero__lead {
    margin-bottom: var(--space-3);
  }
  .oka-hero__ctas {
    margin-bottom: var(--space-3);
  }
  .oka-hero__ctas .btn-ghost-dark {
    width: 100%;
    justify-content: center;
  }
  .oka-hero {
    padding-bottom: var(--space-5);
  }
  .oka-hero__photo {
    height: 320px;
    border-radius: 14px;
    min-height: auto;
  }
  .oka-hero__trust {
    gap: var(--space-1) var(--space-2);
  }
  .oka-hero__award {
    top: 12px;
    right: 12px;
    font-size: 11px;
    padding: 6px 12px 6px 8px;
  }
  .oka-hero__motto {
    padding: 20px 16px 16px;
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .oka-anim {
    opacity: 1;
    animation: none;
  }
}


/* ============================================================
   O KANCELARII — Section 2: Historia i filozofia
   ============================================================ */

.oka-story {
  background: var(--bg-primary);
  padding: clamp(72px, 7vw, 128px) 0;
}

/* Section header */
.oka-story__header {
  margin-bottom: clamp(40px, 4vw, 64px);
}

.oka-story__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--space-2);
}
.oka-story__eyebrow::before {
  content: '';
  display: block;
  width: 32px;
  height: 1px;
  background: linear-gradient(90deg, var(--accent), transparent);
}

.oka-story__headline {
  font-family: var(--font-display);
  font-size: clamp(2rem, 1.4rem + 3vw, 3.25rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--text-primary);
}
.oka-story__headline em {
  font-style: normal;
  font-weight: 500;
  color: var(--accent);
}

/* Asymmetric 2-column grid */
.oka-story__grid {
  display: grid;
  grid-template-columns: 1fr 0.55fr;
  gap: clamp(40px, 4vw, 80px);
  align-items: start;
}

/* Prose column */
.oka-story__prose {
  display: flex;
  flex-direction: column;
  gap: 0;
  max-width: 680px;
}

.oka-story__block {
  margin-bottom: clamp(36px, 3.5vw, 56px);
  padding-bottom: clamp(36px, 3.5vw, 56px);
  border-bottom: 1px solid var(--bg-tertiary);
}
.oka-story__block--last {
  border-bottom: none;
  padding-bottom: 0;
  margin-bottom: 0;
}

.oka-story__subheading {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 1rem + 0.8vw, 1.5rem);
  font-weight: 600;
  line-height: 1.2;
  color: var(--text-primary);
  margin-bottom: var(--space-2);
}
.oka-story__hashtag {
  color: var(--accent);
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 0.75em;
  letter-spacing: 0.5px;
}

.oka-story__text {
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 400;
  line-height: 1.7;
  color: var(--text-secondary);
  margin-bottom: var(--space-2);
}
.oka-story__text:last-child {
  margin-bottom: 0;
}

/* Drop cap on first paragraph */
.oka-story__text--dropcap::first-letter {
  font-family: var(--font-display);
  font-size: 3.4em;
  font-weight: 700;
  float: left;
  line-height: 0.8;
  margin-right: 8px;
  margin-top: 4px;
  color: var(--accent);
}

/* Pull-quote */
.oka-story__quote {
  border-left: 3px solid var(--accent);
  padding-left: 24px;
  margin: clamp(8px, 1vw, 16px) 0 clamp(36px, 3.5vw, 56px);
}
.oka-story__quote p {
  font-family: var(--font-display);
  font-size: clamp(1.15rem, 1rem + 0.7vw, 1.5rem);
  font-weight: 500;
  line-height: 1.5;
  color: var(--text-primary);
}

/* Sticky sidebar */
.oka-story__sidebar {
  position: sticky;
  top: 100px;
  align-self: start;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  max-height: calc(100vh - 140px);
}

/* Sidebar cards */
.oka-story__card {
  position: relative;
  display: flex;
  gap: var(--space-2);
  padding: 20px;
  background: var(--bg-elevated);
  border: 1px solid var(--bg-tertiary);
  border-radius: 12px;
  overflow: hidden;
  transition: box-shadow 0.3s ease, transform 0.3s ease;
}
.oka-story__card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--accent), var(--accent-light));
  opacity: 0;
  transition: opacity 0.3s ease;
}
.oka-story__card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}
.oka-story__card:hover::before {
  opacity: 1;
}

.oka-story__card-icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: var(--accent-bg-solid);
  border: 1px solid var(--accent-border-solid);
}
.oka-story__card-icon svg {
  width: 18px;
  height: 18px;
  stroke: var(--accent);
}

.oka-story__card-body {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.oka-story__card-title {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
}
.oka-story__card-desc {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 400;
  line-height: 1.55;
  color: var(--text-tertiary);
}
.oka-story__card-link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 4px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  transition: gap 0.25s ease;
}
.oka-story__card-link svg {
  width: 14px;
  height: 14px;
  transition: transform 0.25s ease;
}
.oka-story__card-link:hover {
  gap: 6px;
}
.oka-story__card-link:hover svg {
  transform: translateX(2px);
}

/* Reveal animation */
.oka-story-reveal {
  opacity: 0;
  transform: translateY(32px);
  transition:
    opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}
.oka-story-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ── OKA Story responsive ── */

/* Tablet (≤960px) */
@media (max-width: 960px) {
  .oka-story__prose {
    max-width: none;
  }
  .oka-story__grid {
    grid-template-columns: 1fr;
    gap: clamp(32px, 4vw, 48px);
  }
  .oka-story__sidebar {
    position: static;
    max-height: none;
    flex-direction: row;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    gap: var(--space-2);
    padding-bottom: var(--space-1);
    mask-image: linear-gradient(to right, black 85%, transparent 100%);
    -webkit-mask-image: linear-gradient(to right, black 85%, transparent 100%);
  }
  .oka-story__card {
    min-width: 260px;
    scroll-snap-align: start;
    flex-shrink: 0;
  }
}

/* Mobile (≤600px) */
@media (max-width: 600px) {
  .oka-story__sidebar {
    flex-direction: column;
    overflow-x: visible;
    mask-image: none;
    -webkit-mask-image: none;
  }
  .oka-story__card {
    min-width: 0;
  }
  .oka-story__block {
    margin-bottom: var(--space-4);
    padding-bottom: var(--space-4);
  }
  .oka-story__quote {
    margin: var(--space-1) 0 var(--space-4);
  }
  .oka-story__text--dropcap::first-letter {
    font-size: 2.8em;
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .oka-story-reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }
}


/* ============================================================
   O KANCELARII — Section 3: Zespół
   ============================================================ */

.oka-team {
  background: var(--bg-secondary);
  padding: clamp(72px, 7vw, 128px) 0;
}

/* Header — centered */
.oka-team__header {
  text-align: center;
  margin-bottom: clamp(40px, 4vw, 64px);
}

.oka-team__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--space-2);
}
.oka-team__eyebrow::before,
.oka-team__eyebrow::after {
  content: '';
  display: block;
  width: 28px;
  height: 1px;
}
.oka-team__eyebrow::before {
  background: linear-gradient(90deg, transparent, var(--accent));
}
.oka-team__eyebrow::after {
  background: linear-gradient(90deg, var(--accent), transparent);
}

.oka-team__headline {
  font-family: var(--font-display);
  font-size: clamp(2rem, 1.4rem + 3vw, 3.25rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--text-primary);
  margin-bottom: var(--space-2);
}
.oka-team__headline em {
  font-style: normal;
  font-weight: 500;
  color: var(--accent);
}

.oka-team__subtitle {
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 400;
  line-height: 1.6;
  color: var(--text-secondary);
  max-width: 540px;
  margin: 0 auto;
}

/* Cards grid */
.oka-team__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-3);
  align-items: start;
}

/* ── Base card ── */
.oka-team__card {
  position: relative;
  background: var(--bg-elevated);
  border: 1px solid var(--bg-tertiary);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1),
              box-shadow 0.35s ease,
              border-color 0.35s ease;
}

/* Top accent line */
.oka-team__card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  z-index: 3;
  background: linear-gradient(90deg, var(--accent), var(--accent-light), transparent 80%);
  opacity: 0;
  transition: opacity 0.35s ease;
}

/* Mouse-tracking glow */
.oka-team__card::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
  background: radial-gradient(
    500px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),
    rgba(46,107,71,0.04),
    transparent 60%
  );
  opacity: 0;
  transition: opacity 0.4s ease;
  pointer-events: none;
}

.oka-team__card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: var(--accent-border-solid);
}
.oka-team__card:hover::before {
  opacity: 1;
}
.oka-team__card:hover::after {
  opacity: 1;
}

/* ── Photo ── */
.oka-team__photo {
  position: relative;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: var(--bg-tertiary);
}
.oka-team__photo img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

/* Photo gradient overlay */
.oka-team__photo > img + .oka-team__award {
  z-index: 2;
}

/* Placeholder photo — shorter */
.oka-team__photo--placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 4 / 3;
}
.oka-team__photo--placeholder svg {
  width: 48px;
  height: 48px;
  stroke: var(--text-muted);
  opacity: 0.35;
}

/* ── Card body ── */
.oka-team__body {
  position: relative;
  z-index: 2;
  padding: 20px 20px 24px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.oka-team__name {
  font-family: var(--font-display);
  font-size: clamp(1.1rem, 0.9rem + 0.6vw, 1.3rem);
  font-weight: 600;
  line-height: 1.2;
  color: var(--text-primary);
}

/* Role tag — light variant */
.oka-team__role {
  display: inline-block;
  align-self: flex-start;
  padding: 3px 10px;
  border-radius: 100px;
  background: var(--accent-bg-solid);
  border: 1px solid var(--accent-border-solid);
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--accent);
}

.oka-team__desc {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 400;
  line-height: 1.55;
  color: var(--text-tertiary);
  margin-top: 4px;
}

/* ── Contact row ── */
.oka-team__contact {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 10px;
  padding-top: 12px;
  border-top: 1px solid var(--dark-border-subtle);
}
.oka-team__contact-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  color: var(--dark-text-secondary);
  text-decoration: none;
  transition: color 0.25s ease;
}
.oka-team__contact-item svg {
  width: 14px;
  height: 14px;
  stroke: var(--accent-light);
  flex-shrink: 0;
}
.oka-team__contact-item:hover {
  color: var(--accent-light);
}

/* Light variant contact */
.oka-team__contact-item--light {
  color: var(--text-tertiary);
}
.oka-team__contact-item--light svg {
  stroke: var(--accent);
}
.oka-team__contact-item--light:hover {
  color: var(--accent);
}

/* Light card contact border */
.oka-team__card:not(.oka-team__card--featured) .oka-team__contact {
  border-top-color: var(--bg-tertiary);
}

/* ── Social icons ── */
.oka-team__social {
  display: flex;
  gap: 8px;
  margin-top: 8px;
}
.oka-team__social-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: rgba(74,154,106,0.08);
  border: 1px solid rgba(74,154,106,0.15);
  color: var(--accent-light);
  font-size: 13px;
  text-decoration: none;
  transition: all 0.25s ease;
}
.oka-team__social-link:hover {
  background: rgba(74,154,106,0.15);
  transform: translateY(-1px);
}

/* Light variant social */
.oka-team__social-link--light {
  background: var(--accent-bg-solid);
  border-color: var(--accent-border-solid);
  color: var(--accent);
}
.oka-team__social-link--light:hover {
  background: var(--accent-border-solid);
}

/* ══════════════════════════════════════
   Featured card overrides
   ══════════════════════════════════════ */

.oka-team__card--featured .oka-team__photo {
  aspect-ratio: 4 / 3;
}

.oka-team__card--featured {
  background: var(--dark-bg);
  border-color: var(--dark-border);
  box-shadow: 0 4px 24px rgba(0,0,0,0.12);
}
.oka-team__card--featured::before {
  background: linear-gradient(90deg, var(--accent-light), var(--accent), transparent 80%);
  opacity: 0.5;
}
.oka-team__card--featured::after {
  background: radial-gradient(
    500px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),
    rgba(74,154,106,0.06),
    transparent 60%
  );
}
.oka-team__card--featured:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg), 0 0 40px rgba(46,107,71,0.08);
  border-color: var(--dark-border);
}
.oka-team__card--featured:hover::before {
  opacity: 0.8;
}

/* No photo overlay on featured — clean edge */

/* Featured text colors */
.oka-team__card--featured .oka-team__name {
  font-size: clamp(1.25rem, 1rem + 0.8vw, 1.5rem);
  color: var(--text-inverse);
}

.oka-team__role--featured {
  background: rgba(46,107,71,0.08);
  border-color: rgba(46,107,71,0.18);
  color: var(--accent-light);
}

.oka-team__card--featured .oka-team__desc {
  color: var(--dark-text-secondary);
}

/* Registration number */
.oka-team__reg {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  color: var(--dark-text-muted);
  letter-spacing: 0.5px;
}

/* Credentials */
.oka-team__creds {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1) var(--space-2);
  margin-top: 8px;
  padding-top: 12px;
  border-top: 1px solid var(--dark-border-subtle);
}
.oka-team__cred {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 400;
  color: var(--dark-text-muted);
}
.oka-team__cred svg {
  width: 13px;
  height: 13px;
  stroke: var(--accent-light);
  flex-shrink: 0;
}

/* ── Award badge ── */
.oka-team__award {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 4;
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 6px 12px 6px 9px;
  border-radius: 100px;
  background: rgba(15,45,31,0.65);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(46,107,71,0.2);
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  color: var(--dark-text);
  letter-spacing: 0.02em;
  overflow: hidden;
}
.oka-team__award svg {
  width: 13px;
  height: 13px;
  stroke: var(--accent-light);
  fill: none;
  flex-shrink: 0;
}

/* Shimmer effect on award badge */
.oka-team__award::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255,255,255,0.08) 50%,
    transparent 100%
  );
  animation: okaTeamShimmer 4s ease-in-out infinite;
}

@keyframes okaTeamShimmer {
  0%, 100% { left: -100%; }
  50% { left: 100%; }
}

/* ── Reveal animation ── */
.oka-team-reveal {
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}
.oka-team-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ── Responsive ── */

/* Tablet (≤960px) */
@media (max-width: 960px) {
  .oka-team__grid {
    grid-template-columns: 1fr 1fr;
  }
  .oka-team__card--featured {
    grid-column: 1 / -1;
  }
}

/* Mobile (≤600px) */
@media (max-width: 600px) {
  .oka-team__grid {
    grid-template-columns: 1fr;
  }
  .oka-team__card--featured {
    grid-column: auto;
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .oka-team-reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }
  .oka-team__award::after {
    animation: none;
  }
}


/* ============================================================
   O KANCELARII — Section 4: Współpracownicy
   ============================================================ */

.oka-collab {
  background: var(--bg-primary);
  padding: clamp(72px, 7vw, 128px) 0;
}

/* Header */
.oka-collab__header {
  margin-bottom: clamp(32px, 3.5vw, 48px);
}

.oka-collab__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--space-2);
}
.oka-collab__eyebrow::before {
  content: '';
  display: block;
  width: 32px;
  height: 1px;
  background: linear-gradient(90deg, var(--accent), transparent);
}

.oka-collab__headline {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 1.2rem + 2.5vw, 2.75rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--text-primary);
}
.oka-collab__headline em {
  font-style: normal;
  font-weight: 500;
  color: var(--accent);
}

/* Grid */
.oka-collab__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-2);
}

/* Card — entire card is a link */
.oka-collab__card {
  position: relative;
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: 16px;
  background: var(--bg-elevated);
  border: 1px solid var(--bg-tertiary);
  border-radius: 12px;
  text-decoration: none;
  overflow: hidden;
  transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1),
              box-shadow 0.3s ease,
              border-color 0.3s ease;
}
.oka-collab__card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--accent), var(--accent-light), transparent 80%);
  opacity: 0;
  transition: opacity 0.3s ease;
}
.oka-collab__card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: var(--accent-border-solid);
}
.oka-collab__card:hover::before {
  opacity: 1;
}

/* Photo circle */
.oka-collab__photo {
  flex-shrink: 0;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--bg-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.oka-collab__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.oka-collab__photo svg {
  width: 24px;
  height: 24px;
  stroke: var(--text-muted);
  opacity: 0.4;
}

/* Body */
.oka-collab__body {
  flex: 1;
  min-width: 0;
}
.oka-collab__name {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.2;
  color: var(--text-primary);
  margin-bottom: 2px;
}
.oka-collab__title {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  color: var(--text-muted);
}
.oka-collab__link {
  display: block;
  margin-top: 6px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* Arrow */
.oka-collab__arrow {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: var(--accent-bg-solid);
  border: 1px solid var(--accent-border-solid);
  opacity: 0;
  transform: translateX(-4px);
  transition: opacity 0.25s ease, transform 0.25s ease;
}
.oka-collab__arrow svg {
  width: 14px;
  height: 14px;
  stroke: var(--accent);
}
.oka-collab__card:hover .oka-collab__arrow {
  opacity: 1;
  transform: translateX(0);
}

/* Reveal */
.oka-collab-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity 0.6s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}
.oka-collab-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Responsive */
@media (max-width: 960px) {
  .oka-collab__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 600px) {
  .oka-collab__grid {
    grid-template-columns: 1fr;
  }
}
@media (prefers-reduced-motion: reduce) {
  .oka-collab-reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }
}


/* ════════════════════════════════════════════════════════════════
   KONTAKT PAGE — kt- prefix
   ════════════════════════════════════════════════════════════════ */

/* ── Breadcrumbs (17) ── */
.kt-breadcrumbs {
  background: var(--dark-bg);
  padding: var(--space-2) 0 0;
}
.kt-breadcrumbs__list {
  display: flex;
  align-items: center;
  gap: 0;
  list-style: none;
  margin: 0;
  padding: 0;
  font-family: var(--font-body);
  font-size: 13px;
}
.kt-breadcrumbs__item {
  display: flex;
  align-items: center;
  color: var(--dark-text-muted);
}
.kt-breadcrumbs__item + .kt-breadcrumbs__item::before {
  content: '';
  display: inline-block;
  width: 16px;
  height: 16px;
  margin: 0 8px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%237A8A80' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='9 18 15 12 9 6'/%3E%3C/svg%3E") center/contain no-repeat;
  opacity: 0.6;
  flex-shrink: 0;
}
.kt-breadcrumbs__link {
  color: var(--dark-text-secondary);
  text-decoration: none;
  transition: color 0.2s ease;
}
.kt-breadcrumbs__link:hover {
  color: var(--accent-light);
}
.kt-breadcrumbs__item--current {
  color: var(--dark-text-muted);
  font-weight: 500;
}

/* ── Reveal animation base ── */
.kt-reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1),
              transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}
.kt-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ── Staggered hero animations ── */
.kt-anim {
  opacity: 0;
  transform: translateY(24px);
  animation: ktFadeInUp 0.65s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
.kt-anim--1 { animation-delay: 0.05s; }
.kt-anim--2 { animation-delay: 0.15s; }
.kt-anim--3 { animation-delay: 0.25s; }
.kt-anim--4 { animation-delay: 0.4s; }
.kt-anim--5 { animation-delay: 0.55s; }

@keyframes ktFadeInUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}


/* ════════════════════════════════════════════════════
   SECTION 1 — HERO
   ════════════════════════════════════════════════════ */
.kt-hero {
  position: relative;
  background: var(--dark-bg);
  color: var(--dark-text);
  padding: clamp(100px, 12vh, 160px) 0 clamp(72px, 10vh, 120px);
  overflow: hidden;
  text-align: center;
}

/* Subtle gradient overlay for depth */
.kt-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 50% at 50% 0%, rgba(74, 154, 106, 0.08) 0%, transparent 70%),
    radial-gradient(ellipse 40% 60% at 80% 100%, rgba(46, 107, 71, 0.05) 0%, transparent 60%);
  pointer-events: none;
}

.kt-hero__topline {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--accent-light), var(--accent), var(--accent-light), transparent);
  opacity: 0.6;
}

.kt-hero__inner {
  position: relative;
  max-width: 740px;
  margin: 0 auto;
}

.kt-hero__eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--accent-light);
  margin-bottom: var(--space-3);
}

.kt-hero__heading {
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 5vw, 3.6rem);
  font-weight: 700;
  line-height: 1.15;
  margin: 0 0 var(--space-3);
  color: var(--dark-text);
}
.kt-hero__heading em {
  font-style: normal;
  color: var(--accent-light);
}

.kt-hero__lead {
  font-family: var(--font-body);
  font-size: clamp(1rem, 1.8vw, 1.15rem);
  line-height: 1.65;
  color: var(--dark-text-secondary);
  margin: 0 0 var(--space-5);
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}

/* Quick action buttons in hero */
.kt-hero__quick {
  display: flex;
  gap: var(--space-2);
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: var(--space-4);
}

.kt-hero__quick-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 28px;
  border-radius: 10px;
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
  transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
}
.kt-hero__quick-btn svg {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

.kt-hero__quick-btn--phone {
  background: var(--accent-light);
  color: var(--dark-bg);
}
.kt-hero__quick-btn--phone:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(74, 154, 106, 0.35);
}

.kt-hero__quick-btn--form {
  background: transparent;
  color: var(--dark-text);
  border: 1.5px solid var(--dark-border);
}
.kt-hero__quick-btn--form:hover {
  border-color: var(--accent-light);
  color: var(--accent-light);
  transform: translateY(-2px);
}

/* Availability badge */
.kt-hero__availability {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  color: var(--dark-text-secondary);
}
.kt-hero__availability .pulse-dot {
  width: 8px;
  height: 8px;
}

/* Scroll hint */
.kt-hero__scroll-hint {
  position: absolute;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  animation: ktBounce 2s ease-in-out infinite;
}
.kt-hero__scroll-hint svg {
  width: 24px;
  height: 24px;
  stroke: var(--dark-text-muted);
  opacity: 0.5;
}

@keyframes ktBounce {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50% { transform: translateX(-50%) translateY(8px); }
}

/* ── Grain texture overlay (11) ── */
.kt-hero__grain {
  position: absolute;
  inset: 0;
  opacity: 0.035;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-repeat: repeat;
  background-size: 200px 200px;
}

/* ── Parallax container (14) ── */
[data-kt-parallax] {
  will-change: background-position;
  background-attachment: fixed;
}
@media (hover: none) {
  [data-kt-parallax] {
    background-attachment: scroll;
  }
}

/* ── Pulsing ring on CTA (15) ── */
.kt-pulse-ring {
  position: relative;
}
.kt-pulse-ring::before,
.kt-pulse-ring::after {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: inherit;
  border: 2px solid var(--accent-light);
  opacity: 0;
  animation: ktPulseRing 3s cubic-bezier(0.22, 1, 0.36, 1) infinite;
  pointer-events: none;
}
.kt-pulse-ring::after {
  animation-delay: 1.5s;
}
@keyframes ktPulseRing {
  0% { opacity: 0.5; transform: scale(1); }
  100% { opacity: 0; transform: scale(1.12); }
}

/* ── Social proof in hero (5) ── */
.kt-hero__social-proof {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 6px;
  padding: 6px 16px;
  border-radius: 100px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
}
.kt-hero__social-text {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--dark-text-muted);
}
.kt-hero__social-text strong {
  color: var(--dark-text-secondary);
  font-weight: 700;
}

/* ── Hero stats bar ── */
.kt-hero__stats {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  margin-top: var(--space-6);
  padding: var(--space-3) var(--space-4);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 16px;
  backdrop-filter: blur(8px);
}
.kt-hero__stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
.kt-hero__stat-value {
  font-family: var(--font-display);
  font-size: clamp(1.3rem, 2.5vw, 1.7rem);
  font-weight: 700;
  color: var(--accent-light);
  line-height: 1.1;
}
.kt-hero__stat-label {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  color: var(--dark-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.kt-hero__stat-sep {
  width: 1px;
  height: 36px;
  background: rgba(255, 255, 255, 0.1);
  flex-shrink: 0;
}

/* ── Dynamic availability status (1) ── */
#kt-availability.is-closed .pulse-dot {
  background: var(--accent-champagne);
  animation: none;
}
#kt-availability.is-closed .pulse-dot::before {
  display: none;
}


/* ════════════════════════════════════════════════════
   SECTION 2 — CONTACT + FORM
   ════════════════════════════════════════════════════ */
.kt-contact {
  background: var(--bg-primary);
  padding: clamp(64px, 8vh, 100px) 0;
}

.kt-contact__grid {
  display: grid;
  grid-template-columns: 2fr 3fr;
  gap: clamp(40px, 4vw, 64px);
  align-items: start;
}

/* ── Info cards (left column) ── */
.kt-contact__info {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.kt-info-card {
  display: flex;
  gap: var(--space-2);
  padding: var(--space-3);
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 12px;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}
.kt-info-card:hover {
  border-color: var(--accent-border-solid);
  box-shadow: var(--shadow-md);
}

/* Phone card — emphasized */
.kt-info-card--phone {
  background: var(--dark-bg);
  border-color: var(--dark-border);
  color: var(--dark-text);
  padding: var(--space-4) var(--space-3);
}
.kt-info-card--phone:hover {
  border-color: var(--accent-light);
  box-shadow: 0 8px 32px rgba(74, 154, 106, 0.15);
}
.kt-info-card--phone .kt-info-card__icon-wrap {
  background: rgba(74, 154, 106, 0.15);
  color: var(--accent-light);
}
.kt-info-card--phone .kt-info-card__label {
  color: var(--dark-text-secondary);
}
.kt-info-card--phone .kt-info-card__meta {
  color: var(--dark-text-muted);
}

.kt-info-card__icon-wrap {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--accent-bg);
  color: var(--accent);
  border-radius: 10px;
}
.kt-info-card__icon-wrap svg {
  width: 22px;
  height: 22px;
}

.kt-info-card__body {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.kt-info-card__label {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-tertiary);
}

.kt-info-card__value {
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 600;
  color: var(--text-primary);
  text-decoration: none;
  transition: color 0.2s ease;
}
.kt-info-card__value:hover {
  color: var(--accent);
}
.kt-info-card__value--big {
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--dark-text);
}
.kt-info-card__value--big:hover {
  color: var(--accent-light);
}

.kt-info-card__address {
  font-style: normal;
  line-height: 1.6;
}

.kt-info-card__directions {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  margin-top: 4px;
  transition: gap 0.2s ease;
}
.kt-info-card__directions:hover {
  gap: 10px;
}
.kt-info-card__directions svg {
  transform: rotate(45deg);
}

.kt-info-card__meta {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text-muted);
  display: flex;
  align-items: center;
  gap: 8px;
}
.kt-info-card__meta .pulse-dot {
  width: 6px;
  height: 6px;
}
.kt-info-card__meta--accent {
  color: var(--accent);
  font-weight: 500;
}

/* Messenger buttons */
.kt-info-card__messenger-links {
  display: flex;
  gap: 10px;
  margin: 4px 0;
}

.kt-messenger-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  border-radius: 8px;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.kt-messenger-btn:hover {
  transform: translateY(-1px);
}
.kt-messenger-btn i {
  font-size: 18px;
}

.kt-messenger-btn--wa {
  background: #25D366;
  color: #fff;
}
.kt-messenger-btn--wa:hover {
  box-shadow: 0 4px 16px rgba(37, 211, 102, 0.3);
}
.kt-messenger-btn--signal {
  background: #3A76F0;
  color: #fff;
}
.kt-messenger-btn--signal:hover {
  box-shadow: 0 4px 16px rgba(58, 118, 240, 0.3);
}

/* Hours */
.kt-info-card__hours {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.kt-hours-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text-secondary);
  padding: 6px 0;
}
.kt-hours-row + .kt-hours-row {
  border-top: 1px solid var(--border);
}

/* ── Phone card actions row (copy + availability inline) ── */
.kt-info-card__actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 4px;
}

/* ── Staggered card reveal (4) ── */
.kt-info-card.kt-reveal { transition-delay: 0s; }
.kt-info-card.kt-reveal[data-kt-stagger="1"] { transition-delay: 0.1s; }
.kt-info-card.kt-reveal[data-kt-stagger="2"] { transition-delay: 0.2s; }
.kt-info-card.kt-reveal[data-kt-stagger="3"] { transition-delay: 0.3s; }
.kt-info-card.kt-reveal[data-kt-stagger="4"] { transition-delay: 0.4s; }

/* ── Copy button (7) ── */
.kt-copy-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 12px;
  border: 1px solid var(--dark-border);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.06);
  color: var(--dark-text-secondary);
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
  margin-top: 4px;
  align-self: flex-start;
}
.kt-copy-btn:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: var(--accent-light);
  color: var(--accent-light);
}
.kt-copy-btn svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}
.kt-copy-btn__check {
  display: none;
}
.kt-copy-btn.is-copied .kt-copy-btn__icon { display: none; }
.kt-copy-btn.is-copied .kt-copy-btn__check { display: block; stroke: var(--accent-light); }
.kt-copy-btn.is-copied .kt-copy-btn__text { color: var(--accent-light); }
.kt-copy-btn.is-copied {
  border-color: var(--accent-light);
  background: rgba(74, 154, 106, 0.12);
}

/* ── Mouse-tracking glow on cards (12) ── */
[data-kt-glow] {
  --glow-x: 50%;
  --glow-y: 50%;
  position: relative;
  overflow: hidden;
}
[data-kt-glow]::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(
    300px circle at var(--glow-x) var(--glow-y),
    rgba(74, 154, 106, 0.08) 0%,
    transparent 70%
  );
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.35s ease;
}
[data-kt-glow]:hover::after {
  opacity: 1;
}
/* Dark card gets brighter glow */
.kt-info-card--phone[data-kt-glow]::after {
  background: radial-gradient(
    300px circle at var(--glow-x) var(--glow-y),
    rgba(74, 154, 106, 0.15) 0%,
    transparent 70%
  );
}


/* ── Form card (right column) ── */
.kt-contact__form-wrap {
  position: sticky;
  top: 100px;
}

.kt-form-card {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}

.kt-form-card__header {
  padding: var(--space-4) var(--space-4) 0;
}

.kt-form-card__title {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 2.5vw, 1.85rem);
  font-weight: 700;
  color: var(--text-primary);
  margin: 0 0 8px;
}

.kt-form-card__subtitle {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text-tertiary);
  line-height: 1.55;
  margin: 0;
}

/* Progress bar */
.kt-form-progress {
  height: 3px;
  background: var(--bg-secondary);
  margin: var(--space-3) var(--space-4) 0;
  border-radius: 3px;
  overflow: hidden;
}
.kt-form-progress__bar {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--accent), var(--accent-light));
  border-radius: 3px;
  transition: width 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}

/* Form */
.kt-form {
  padding: var(--space-3) var(--space-4) var(--space-4);
  display: flex;
  flex-direction: column;
  gap: 0;
}
.kt-form[hidden] {
  display: none;
}
.kt-form-card__header[hidden],
.kt-form-progress[hidden] {
  display: none;
}

.kt-form__group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.kt-form__label {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
}
.kt-form__req {
  color: var(--accent);
  font-weight: 700;
}
.kt-form__optional {
  font-weight: 400;
  color: var(--text-muted);
  font-size: 12px;
}

.kt-form__input,
.kt-form__select,
.kt-form__textarea {
  font-family: var(--font-body);
  font-size: 15px;
  color: var(--text-primary);
  background: var(--bg-primary);
  border: 1.5px solid var(--border);
  border-radius: 8px;
  padding: 12px 14px;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
  outline: none;
  width: 100%;
  box-sizing: border-box;
}
.kt-form__input::placeholder,
.kt-form__textarea::placeholder {
  color: var(--text-muted);
}

.kt-form__input:focus,
.kt-form__select:focus,
.kt-form__textarea:focus {
  border-color: var(--accent);
  box-shadow: var(--shadow-focus);
  background: var(--bg-elevated);
}

/* Validation states */
.kt-form__input.is-valid,
.kt-form__select.is-valid,
.kt-form__textarea.is-valid {
  border-color: var(--accent);
}
.kt-form__input.is-invalid,
.kt-form__select.is-invalid,
.kt-form__textarea.is-invalid {
  border-color: #C0392B;
  box-shadow: 0 0 0 3px rgba(192, 57, 43, 0.1);
}

.kt-form__error {
  font-family: var(--font-body);
  font-size: 12px;
  color: #C0392B;
  min-height: 0;
  overflow: hidden;
  transition: min-height 0.25s ease;
}
.kt-form__error:not(:empty) {
  min-height: 18px;
}

/* Select wrapper */
.kt-form__select-wrap {
  position: relative;
}
.kt-form__select {
  appearance: none;
  padding-right: 40px;
  cursor: pointer;
}
.kt-form__select-chevron {
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  stroke: var(--text-muted);
  pointer-events: none;
}

/* Textarea */
.kt-form__textarea {
  resize: vertical;
  min-height: 120px;
  max-height: 300px;
}
.kt-form__textarea-footer {
  display: flex;
  justify-content: flex-end;
}
.kt-form__char-count {
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--text-muted);
}

/* Checkbox */
.kt-form__group--checkbox {
  gap: 8px;
}
.kt-form__checkbox-label {
  display: flex;
  gap: 12px;
  cursor: pointer;
  align-items: flex-start;
}
.kt-form__checkbox {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.kt-form__checkbox-box {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  border: 1.5px solid var(--border);
  border-radius: 5px;
  background: var(--bg-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s ease, border-color 0.2s ease;
  margin-top: 1px;
}
.kt-form__checkbox-box svg {
  width: 14px;
  height: 14px;
  stroke: #fff;
  opacity: 0;
  transform: scale(0.6);
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.kt-form__checkbox:checked + .kt-form__checkbox-box {
  background: var(--accent);
  border-color: var(--accent);
}
.kt-form__checkbox:checked + .kt-form__checkbox-box svg {
  opacity: 1;
  transform: scale(1);
}
.kt-form__checkbox:focus-visible + .kt-form__checkbox-box {
  box-shadow: var(--shadow-focus);
}
.kt-form__checkbox-text {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text-tertiary);
  line-height: 1.55;
}
.kt-form__checkbox-text a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* Submit button */
.kt-form__submit {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 16px 32px;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 10px;
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.2s ease, transform 0.25s ease, box-shadow 0.25s ease;
  margin-top: var(--space-1);
  overflow: hidden;
}
.kt-form__submit:hover:not(:disabled) {
  background: var(--accent-hover);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(46, 107, 71, 0.25);
}
.kt-form__submit:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

.kt-form__submit-text,
.kt-form__submit-sending,
.kt-form__submit-done {
  display: flex;
  align-items: center;
  gap: 8px;
}
.kt-form__submit-sending,
.kt-form__submit-done {
  position: absolute;
  inset: 0;
  justify-content: center;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.3s ease, transform 0.3s ease;
  pointer-events: none;
}
.kt-form__submit-done svg {
  width: 20px;
  height: 20px;
}

/* Submit states */
.kt-form__submit.is-sending .kt-form__submit-text { opacity: 0; transform: translateY(-8px); }
.kt-form__submit.is-sending .kt-form__submit-sending { opacity: 1; transform: translateY(0); }
.kt-form__submit.is-done { background: var(--accent-light); }
.kt-form__submit.is-done .kt-form__submit-text { opacity: 0; transform: translateY(-8px); }
.kt-form__submit.is-done .kt-form__submit-done { opacity: 1; transform: translateY(0); }

/* Spinner */
.kt-spinner {
  width: 18px;
  height: 18px;
  border: 2.5px solid rgba(255, 255, 255, 0.3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: ktSpin 0.65s linear infinite;
}
@keyframes ktSpin {
  to { transform: rotate(360deg); }
}

/* ── Success screen (3) ── */
.kt-form-success {
  padding: var(--space-6) var(--space-4);
  text-align: center;
  animation: ktFadeInUp 0.5s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
.kt-form-success[hidden] {
  display: none;
}
.kt-form-success__icon {
  width: 64px;
  height: 64px;
  margin: 0 auto var(--space-3);
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--accent-bg-solid);
  border-radius: 50%;
}
.kt-form-success__icon svg {
  width: 32px;
  height: 32px;
  stroke: var(--accent);
}
.kt-form-success__title {
  font-family: var(--font-display);
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0 0 var(--space-1);
}
.kt-form-success__text {
  font-family: var(--font-body);
  font-size: 15px;
  color: var(--text-tertiary);
  line-height: 1.6;
  margin: 0 0 var(--space-4);
}
.kt-form-success__what-next {
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: var(--space-3);
  margin-bottom: var(--space-4);
  text-align: left;
}
.kt-form-success__what-next-title {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  margin: 0 0 var(--space-2);
}
.kt-form-success__steps {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.kt-form-success__steps li {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text-secondary);
}
.kt-form-success__steps svg {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  color: var(--accent);
}
.kt-form-success__cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
}
.kt-form-success__cta-label {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text-muted);
}
.kt-form-success__cta .btn-primary {
  min-width: 200px;
  justify-content: center;
}

/* ── Phone auto-format visual (6) ── */
.kt-form__input[data-formatted] {
  letter-spacing: 0.04em;
}

/* ── Map placeholder (9) ── */
.kt-map__placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  min-height: 420px;
  background: var(--bg-secondary);
}
.kt-map__placeholder-icon {
  width: 40px;
  height: 40px;
  color: var(--text-muted);
  animation: ktPulseMap 1.5s ease-in-out infinite;
}
.kt-map__placeholder-text {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text-muted);
}
.kt-map__placeholder.is-hidden {
  display: none;
}
@keyframes ktPulseMap {
  0%, 100% { opacity: 0.4; }
  50% { opacity: 1; }
}


/* ════════════════════════════════════════════════════
   SECTION 3 — TRUST STRIP
   ════════════════════════════════════════════════════ */
.kt-trust {
  position: relative;
  background: var(--bg-secondary);
  padding: var(--space-5) 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

.kt-trust__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.kt-trust__item {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text-secondary);
  line-height: 1.5;
}
.kt-trust__item strong {
  color: var(--text-primary);
  font-weight: 700;
}
.kt-trust__item a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.kt-trust__icon {
  width: 28px;
  height: 28px;
  flex-shrink: 0;
  color: var(--accent);
}

.kt-trust__sep {
  width: 1px;
  height: 32px;
  background: var(--border);
  flex-shrink: 0;
}

/* ── Animated line (13) ── */
.kt-trust__line {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%) scaleX(0);
  width: 80%;
  max-width: 600px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
  transition: transform 1s cubic-bezier(0.22, 1, 0.36, 1);
  transform-origin: center;
}
.kt-trust__line.is-drawn {
  transform: translateX(-50%) scaleX(1);
}


/* ════════════════════════════════════════════════════
   SECTION 4 — MAP
   ════════════════════════════════════════════════════ */
.kt-map {
  background: var(--bg-primary);
  padding: clamp(64px, 8vh, 100px) 0;
}

.kt-map__header {
  text-align: center;
  margin-bottom: var(--space-6);
}

.kt-map__eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--space-1);
}

.kt-map__headline {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 700;
  color: var(--text-primary);
  margin: 0 0 8px;
}

.kt-map__sub {
  font-family: var(--font-body);
  font-size: 15px;
  color: var(--text-tertiary);
  margin: 0;
}

.kt-map__embed-wrap {
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-lg);
}

.kt-map__iframe {
  display: block;
  width: 100%;
  height: 420px;
}

.kt-map__footer {
  margin-top: var(--space-3);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.kt-map__address-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 500;
  color: var(--text-primary);
}
.kt-map__address-bar svg {
  width: 20px;
  height: 20px;
  color: var(--accent);
  flex-shrink: 0;
}

.kt-map__transport {
  display: flex;
  gap: var(--space-3);
}
.kt-map__transport-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text-tertiary);
}
.kt-map__transport-item svg {
  color: var(--text-muted);
  flex-shrink: 0;
}


/* ════════════════════════════════════════════════════
   SECTION 5 — FAQ
   ════════════════════════════════════════════════════ */
.kt-faq {
  background: var(--bg-secondary);
  padding: clamp(64px, 8vh, 100px) 0;
}

.kt-faq__header {
  text-align: center;
  margin-bottom: var(--space-6);
}

.kt-faq__eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--space-1);
}

.kt-faq__headline {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 700;
  color: var(--text-primary);
  margin: 0;
}

.kt-faq__grid {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: clamp(32px, 4vw, 56px);
  align-items: start;
}

/* Accordion */
.kt-faq__accordion {
  display: flex;
  flex-direction: column;
}

.kt-faq__item {
  border-bottom: 1px solid var(--border);
}
.kt-faq__item:first-child {
  border-top: 1px solid var(--border);
}

.kt-faq__question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  width: 100%;
  padding: var(--space-3) 0;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 600;
  color: var(--text-primary);
  transition: color 0.2s ease;
}
.kt-faq__question:hover {
  color: var(--accent);
}

.kt-faq__icon {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
}
.kt-faq__icon svg {
  width: 24px;
  height: 24px;
  stroke: var(--text-muted);
  transition: stroke 0.2s ease;
}
.kt-faq__question:hover .kt-faq__icon svg {
  stroke: var(--accent);
}

.kt-faq__icon-v {
  transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.3s ease;
  transform-origin: center;
}
.kt-faq__question[aria-expanded="true"] .kt-faq__icon-v {
  transform: scaleY(0);
  opacity: 0;
}

.kt-faq__answer {
  overflow: hidden;
  transition: max-height 0.4s cubic-bezier(0.22, 1, 0.36, 1);
  max-height: 0;
}
.kt-faq__answer[hidden] {
  display: block !important;
  max-height: 0;
}
.kt-faq__answer.is-open {
  max-height: 400px;
}

.kt-faq__answer-inner {
  padding: 0 0 var(--space-3);
}
.kt-faq__answer-inner p {
  font-family: var(--font-body);
  font-size: 15px;
  color: var(--text-secondary);
  line-height: 1.7;
  margin: 0;
}
.kt-faq__answer-inner a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 2px;
  font-weight: 600;
}

/* Sidebar */
.kt-faq__sidebar {
  position: sticky;
  top: 100px;
}

.kt-faq__sidebar-card {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: var(--space-4);
  text-align: center;
  box-shadow: var(--shadow-md);
}

.kt-faq__sidebar-icon {
  width: 48px;
  height: 48px;
  margin: 0 auto var(--space-2);
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--accent-bg);
  border-radius: 12px;
}
.kt-faq__sidebar-icon svg {
  width: 24px;
  height: 24px;
  stroke: var(--accent);
}

.kt-faq__sidebar-headline {
  font-family: var(--font-display);
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0 0 8px;
}

.kt-faq__sidebar-text {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text-tertiary);
  line-height: 1.6;
  margin: 0 0 var(--space-3);
}

.kt-faq__sidebar-card .btn-primary {
  width: 100%;
  justify-content: center;
}

.kt-faq__sidebar-meta {
  display: flex;
  gap: 8px;
  justify-content: center;
  margin-top: var(--space-2);
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text-muted);
}


/* ════════════════════════════════════════════════════
   RESPONSIVE — KONTAKT
   ════════════════════════════════════════════════════ */

@media (max-width: 1100px) {
  .kt-faq__grid {
    grid-template-columns: 1fr;
  }
  .kt-faq__sidebar {
    position: static;
  }
}

@media (max-width: 960px) {
  .kt-contact__grid {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }

  .kt-contact__form-wrap {
    position: static;
  }

  .kt-trust__sep {
    display: none;
  }
  .kt-trust__inner {
    flex-direction: column;
    gap: var(--space-2);
    text-align: center;
  }
  .kt-trust__item {
    justify-content: center;
  }

  .kt-map__footer {
    flex-direction: column;
    align-items: flex-start;
  }
  .kt-map__transport {
    flex-direction: column;
    gap: var(--space-1);
  }
}

@media (max-width: 600px) {
  .kt-hero__quick {
    flex-direction: column;
  }
  .kt-hero__quick-btn {
    justify-content: center;
  }

  .kt-hero__stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-3);
    padding: var(--space-3);
  }
  .kt-hero__stat-sep {
    display: none;
  }

  .kt-info-card {
    flex-direction: column;
    text-align: center;
    align-items: center;
  }
  .kt-info-card__meta {
    justify-content: center;
  }
  .kt-info-card__messenger-links {
    justify-content: center;
  }
  .kt-hours-row {
    flex-direction: column;
    text-align: center;
    gap: 6px;
  }

  .kt-map__iframe {
    height: 300px;
  }

  .kt-form-card__header {
    padding: var(--space-3) var(--space-3) 0;
  }
  .kt-form-progress {
    margin-left: var(--space-3);
    margin-right: var(--space-3);
  }
  .kt-form {
    padding: var(--space-3);
  }
}

@media (prefers-reduced-motion: reduce) {
  .kt-anim {
    animation: none;
    opacity: 1;
    transform: none;
  }
  .kt-reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }
  .kt-hero__scroll-hint {
    animation: none;
  }
  .kt-faq__answer {
    transition: none;
  }
}


/* ============================================================
   BLOG TEMPLATE
   ============================================================
   Layout architecture:
   - Trust bar & Urgency banner: full-width, centered content
   - Hero: full-width dark bg, content uses .container
   - Sections 4–10: unified grid (content + sidebar)
     Left column spans content, right column = 300px sidebar
     QA, Author, TOC-mobile, article all live in left column
   ============================================================ */

/* ── Section 1: Trust Bar ── */
.blog-trust {
  background: var(--bg-secondary);
  /* padding-top clears fixed header: top-bar 44px + nav ~72px ≈ 116px */
  padding: 100px 0 10px;
}

.blog-trust__inner {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 clamp(20px, 12px + 3vw, 96px);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 20px;
}

.blog-trust__item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  color: var(--text-muted);
  white-space: nowrap;
}

.blog-trust__icon {
  width: 14px;
  height: 14px;
  color: var(--accent-light);
  flex-shrink: 0;
}

.blog-trust__dot {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: var(--bg-tertiary);
  flex-shrink: 0;
}

@media (max-width: 600px) {
  .blog-trust__inner { gap: 12px; }
  .blog-trust__item { font-size: 11px; }
}


/* ── Section 2: Urgency Banner (conditional) ── */
.blog-urgency {
  background: var(--dark-bg-alt);
  padding: 14px 0;
}

.blog-urgency[hidden] { display: none; }

.blog-urgency__inner {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 clamp(20px, 12px + 3vw, 96px);
}

.blog-urgency__desktop {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
}

.blog-urgency__mobile { display: none; }

.blog-urgency__pulse {
  width: 8px;
  height: 8px;
  background: var(--emergency-accent);
  border-radius: 50%;
  position: relative;
  flex-shrink: 0;
}

.blog-urgency__pulse::after {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  background: var(--emergency-accent);
  opacity: 0;
  animation: pulse 2s ease-in-out infinite;
}

.blog-urgency__text {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--emergency-text);
}

.blog-urgency__phone {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 700;
  color: var(--emergency-accent);
  text-decoration: none;
  transition: opacity 0.2s ease;
}

.blog-urgency__phone:hover { opacity: 0.8; }

@media (max-width: 768px) {
  .blog-urgency__desktop { display: none; }
  .blog-urgency__mobile {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 48px;
    text-decoration: none;
    color: var(--emergency-text);
  }
  .blog-urgency__mobile .blog-urgency__text { font-size: 13px; }
}


/* ── Section 3: Blog Hero ── */
.blog-hero {
  background: var(--dark-bg);
  padding: clamp(80px, 8vw, 120px) 0 clamp(48px, 5vw, 72px);
}

.blog-hero__inner {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 clamp(20px, 12px + 3vw, 96px);
}

.blog-hero__breadcrumbs { margin-bottom: 20px; }

.blog-hero__breadcrumbs ol {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  list-style: none;
  padding: 0;
  margin: 0;
}

.blog-hero__breadcrumbs li {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--dark-text-muted);
  line-height: 1.4;
}

.blog-hero__breadcrumbs li:not(:last-child)::after {
  content: '›';
  margin: 0 8px;
  color: var(--dark-text-muted);
  opacity: 0.5;
}

.blog-hero__breadcrumbs a {
  color: var(--dark-text-muted);
  text-decoration: none;
  transition: color 0.2s ease;
}

.blog-hero__breadcrumbs a:hover { color: var(--dark-text); }

.blog-hero__breadcrumbs li:last-child { opacity: 0.7; }

.blog-hero__code-badge {
  display: inline-block;
  padding: 4px 12px;
  border-radius: 100px;
  background: rgba(74, 154, 106, 0.1);
  border: 1px solid rgba(74, 154, 106, 0.2);
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  color: var(--accent-light);
  letter-spacing: 0.3px;
  text-transform: uppercase;
  margin-bottom: 16px;
}

.blog-hero__code-badge[hidden] { display: none; }

.blog-hero__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 1.4rem + 3vw, 3.5rem);
  font-weight: 700;
  color: var(--dark-text);
  line-height: 1.15;
  margin-bottom: 16px;
  letter-spacing: -0.01em;
  max-width: 780px;
}

.blog-hero__lead {
  font-family: var(--font-body);
  font-size: clamp(1rem, 0.95rem + 0.25vw, 1.15rem);
  font-weight: 400;
  color: var(--dark-text-secondary);
  line-height: 1.7;
  max-width: 680px;
  margin-bottom: 20px;
}

.blog-hero__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 16px;
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--dark-text-muted);
}

.blog-hero__meta-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.blog-hero__meta-item svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  opacity: 0.6;
}

.blog-hero__updated-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 100px;
  background: var(--accent-bg-solid);
  color: var(--accent);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.3px;
  text-transform: uppercase;
  line-height: 1.4;
}

.blog-hero__meta-updated[hidden] { display: none; }

.blog-hero__image {
  margin-top: 32px;
  margin-bottom: 0;
  position: relative;
}

.blog-hero__image-badge {
  position: absolute;
  top: 16px;
  right: 16px;
  background: var(--accent);
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.3px;
  padding: 8px 18px;
  border-radius: 8px;
  line-height: 1;
}

.blog-hero__image img {
  width: 100%;
  max-width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  border-radius: 12px;
  object-fit: cover;
  display: block;
}

/* Hero animations */
.blog-hero__breadcrumbs,
.blog-hero__code-badge,
.blog-hero__title,
.blog-hero__lead,
.blog-hero__meta,
.blog-hero__image {
  opacity: 0;
  transform: translateY(16px);
  animation: blogHeroFadeIn 0.6s ease-out forwards;
}

.blog-hero__breadcrumbs { animation-delay: 0.05s; }
.blog-hero__code-badge  { animation-delay: 0.12s; }
.blog-hero__title       { animation-delay: 0.18s; }
.blog-hero__lead        { animation-delay: 0.26s; }
.blog-hero__meta        { animation-delay: 0.34s; }
.blog-hero__image       { animation-delay: 0.42s; }

@keyframes blogHeroFadeIn {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
  .blog-hero__breadcrumbs,
  .blog-hero__code-badge,
  .blog-hero__title,
  .blog-hero__lead,
  .blog-hero__meta,
  .blog-hero__image {
    animation: none;
    opacity: 1;
    transform: none;
  }
}

@media (max-width: 600px) {
  .blog-hero { padding: clamp(60px, 6vw, 80px) 0 clamp(32px, 4vw, 48px); }
  .blog-hero__image img { border-radius: 8px; }
  .blog-hero__meta { gap: 10px; }
}


/* ============================================================
   BLOG — Unified Content + Sidebar Grid (Sections 4–10)
   ============================================================ */
.blog-layout {
  background: var(--bg-primary);
  padding: clamp(32px, 4vw, 48px) 0;
}

.blog-layout__inner {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 clamp(20px, 12px + 3vw, 96px);
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: clamp(32px, 3.5vw, 56px);
  align-items: start;
}

.blog-layout__content {
  min-width: 0;
  max-width: 780px;
}


/* ── Section 4: Quick Answer (inside left column) ── */
.blog-qa {
  margin-bottom: clamp(20px, 2.5vw, 28px);
}

.blog-qa[hidden] { display: none; }

.blog-qa__box {
  padding: 20px 24px;
  background: var(--bg-elevated);
  border-left: 4px solid var(--accent);
  border-radius: 0 12px 12px 0;
  box-shadow: var(--shadow-sm);
}

.blog-qa__text {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text-secondary);
  line-height: 1.7;
  margin: 0 0 12px;
}

.blog-qa__text strong {
  font-weight: 700;
  color: var(--text-primary);
}

.blog-qa__cta {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text-secondary);
  line-height: 1.7;
  margin: 0;
}

.blog-qa__cta a {
  color: var(--accent);
  font-weight: 600;
  text-decoration: none;
  transition: color 0.2s ease;
}

.blog-qa__cta a:hover { color: var(--accent-hover); }

/* QA reveal animation */
.blog-qa__box {
  opacity: 0;
  transform: translateY(12px);
}

.blog-qa__box.is-visible {
  animation: blogQaReveal 0.5s ease-out forwards;
}

@keyframes blogQaReveal {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
  .blog-qa__box { opacity: 1; transform: none; }
  .blog-qa__box.is-visible { animation: none; }
}

@media (max-width: 600px) {
  .blog-qa__box { padding: 16px 18px; }
}


/* ── Section 5: Author E-E-A-T (inside left column) ── */
.blog-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--border);
}

.blog-tags__label {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1;
  padding: 6px 0;
}

.blog-tags__item {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-secondary);
  background: var(--bg-secondary);
  padding: 6px 14px;
  border-radius: 6px;
  line-height: 1;
}

/* ── Blog Share ── */
.blog-share {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid var(--border);
}

.blog-share__label {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1;
}

.blog-share__buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.blog-share__btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 500;
  line-height: 1;
  padding: 7px 14px;
  border-radius: 6px;
  border: 1px solid var(--border);
  background: var(--bg-primary);
  color: var(--text-secondary);
  text-decoration: none;
  cursor: pointer;
  transition: background .2s, color .2s, border-color .2s;
}

.blog-share__btn svg {
  width: 15px;
  height: 15px;
  flex-shrink: 0;
}

.blog-share__btn:hover {
  background: var(--bg-secondary);
  color: var(--text-primary);
  border-color: var(--text-tertiary);
}

.blog-share__btn--copy.is-copied {
  background: var(--accent, #2563eb);
  color: #fff;
  border-color: var(--accent, #2563eb);
}

.blog-share__btn--facebook:hover  { color: #1877F2; border-color: #1877F2; }
.blog-share__btn--linkedin:hover  { color: #0A66C2; border-color: #0A66C2; }

.blog-share__btn--whatsapp:hover  { color: #25D366; border-color: #25D366; }
.blog-share__btn--email:hover     { color: var(--text-primary); }

.blog-share__btn--whatsapp svg { width: 16px; height: 16px; }

@media (max-width: 480px) {
  .blog-share__btn span { display: none; }
  .blog-share__btn { padding: 8px 10px; }
}

/* ── Blog Disclaimer ── */
.blog-disclaimer {
  margin-top: 24px;
  padding: 20px 24px;
  background: var(--bg-secondary);
  border-left: 3px solid var(--border);
  border-radius: 0 8px 8px 0;
}

.blog-disclaimer__text {
  font-size: 12px;
  line-height: 1.65;
  color: var(--text-tertiary);
  margin: 0;
}

.blog-disclaimer__text + .blog-disclaimer__text {
  margin-top: 8px;
}

.blog-author {
  display: flex;
  gap: 20px;
  margin-bottom: clamp(24px, 3vw, 32px);
  padding: 20px;
  background: var(--bg-elevated);
  border: 1px solid var(--bg-tertiary);
  border-radius: 12px;
}

.blog-author__body {
  flex: 1;
  min-width: 0;
}

.blog-author__photo {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  border: 2px solid var(--bg-tertiary);
  object-fit: cover;
  flex-shrink: 0;
}

.blog-author__info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.blog-author__name {
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.3;
}

.blog-author__role {
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.4;
}

.blog-author__bio {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.5;
  margin: 6px 0 0;
}

.blog-author__bottom {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 10px;
}

.blog-author__google {
  display: flex;
  align-items: center;
  gap: 4px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  color: var(--text-muted);
}

.blog-author__google svg {
  width: 12px;
  height: 12px;
  fill: var(--accent);
}

.blog-author__more {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  margin-left: auto;
  transition: gap 0.2s ease;
}

.blog-author__more:hover { gap: 8px; }

.blog-author__more svg {
  width: 14px;
  height: 14px;
}

@media (max-width: 600px) {
  .blog-author {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 12px;
  }
  .blog-author__photo {
    width: 56px;
    height: 56px;
  }
  .blog-author__info { align-items: center; }
  .blog-author__bottom {
    justify-content: center;
    flex-wrap: wrap;
    gap: 8px 16px;
  }
  .blog-author__more { margin-left: 0; }
}


/* ── Mobile TOC accordion ── */
.blog-toc-mobile { display: none; }

@media (max-width: 960px) {
  .blog-toc-mobile {
    display: block;
    margin-bottom: 24px;
    border: 1px solid var(--bg-tertiary);
    border-radius: 10px;
    background: var(--bg-elevated);
  }

  .blog-toc-mobile__trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 14px 16px;
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 600;
    color: var(--text-primary);
    background: none;
    border: none;
    cursor: pointer;
  }

  .blog-toc-mobile__chevron {
    width: 16px;
    height: 16px;
    transition: transform 0.25s ease;
  }

  .blog-toc-mobile__trigger[aria-expanded="true"] .blog-toc-mobile__chevron {
    transform: rotate(180deg);
  }

  .blog-toc-mobile__panel {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
  }

  .blog-toc-mobile__panel.is-open { max-height: 600px; }

  .blog-toc-mobile__panel ol {
    list-style: none;
    padding: 0 16px 14px;
    margin: 0;
    border-top: 1px solid var(--bg-tertiary);
  }

  .blog-toc-mobile__panel li { margin: 0; }

  .blog-toc-mobile__panel a {
    display: block;
    padding: 8px 0;
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 500;
    color: var(--text-muted);
    text-decoration: none;
    transition: color 0.2s ease;
  }

  .blog-toc-mobile__panel a:hover { color: var(--accent); }
}


/* ── Sidebar ── */
.blog-sidebar {
  position: sticky;
  top: 80px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* Sidebar CTA dark box */
.blog-sidebar__cta {
  background: var(--dark-bg);
  border: 1px solid var(--dark-border);
  border-radius: 14px;
  padding: 24px;
  text-align: center;
}

.blog-sidebar__cta-heading {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 700;
  color: var(--dark-text);
  margin: 0 0 8px;
}

.blog-sidebar__cta-phone {
  display: block;
  font-family: var(--font-body);
  font-size: 20px;
  font-weight: 700;
  color: var(--accent-light);
  text-decoration: none;
  margin-bottom: 4px;
  transition: opacity 0.2s ease;
}

.blog-sidebar__cta-phone:hover { opacity: 0.8; }

.blog-sidebar__cta-avail {
  font-family: var(--font-body);
  font-size: 11px;
  color: var(--dark-text-muted);
  margin: 0 0 12px;
}

.blog-sidebar__cta-sep {
  border: none;
  border-top: 1px solid var(--dark-border);
  margin: 0 0 12px;
}

.blog-sidebar__cta-price {
  font-family: var(--font-body);
  font-size: 11px;
  color: var(--dark-text-muted);
  margin: 0;
}

/* Sidebar TOC */
.blog-sidebar__toc {
  background: var(--bg-elevated);
  border: 1px solid var(--bg-tertiary);
  border-radius: 14px;
  padding: 22px;
}

.blog-sidebar__toc-title {
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--accent);
  margin: 0;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--bg-tertiary);
}

.blog-sidebar__toc-list {
  list-style: none;
  padding: 0;
  margin: 10px 0 0;
  border-left: 2px solid var(--bg-tertiary);
  max-height: 35vh;
  overflow-y: auto;
}

.blog-sidebar__toc-list li { margin: 0; }

.blog-sidebar__toc-list a {
  display: block;
  padding: 6px 0 6px 14px;
  margin-left: -2px;
  border-left: 2px solid transparent;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  color: var(--text-muted);
  text-decoration: none;
  transition: color 0.2s ease, padding-left 0.2s ease, border-color 0.2s ease;
}

.blog-sidebar__toc-list a:hover {
  padding-left: 20px;
  border-left-color: var(--accent-border-solid);
  color: var(--text-secondary);
}

.blog-sidebar__toc-list a.is-active {
  color: var(--accent);
  font-weight: 600;
  border-left-color: var(--accent);
}

/* Sidebar popular posts */
.blog-sidebar__popular {
  background: var(--bg-elevated);
  border: 1px solid var(--bg-tertiary);
  border-radius: 14px;
  padding: 22px;
}

.blog-sidebar__popular-title {
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--accent);
  margin: 0 0 14px;
}

.blog-sidebar__popular-list {
  list-style: none;
  margin: 0;
  padding: 0;
  counter-reset: popular;
}

.blog-sidebar__popular-item {
  counter-increment: popular;
  border-bottom: 1px solid var(--bg-tertiary);
  padding: 10px 0;
}

.blog-sidebar__popular-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.blog-sidebar__popular-item:first-child {
  padding-top: 0;
}

.blog-sidebar__popular-link {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  text-decoration: none;
  color: var(--text-primary);
  transition: color 0.2s ease;
}

.blog-sidebar__popular-link::before {
  content: counter(popular) ".";
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 700;
  color: var(--accent);
  flex-shrink: 0;
  min-width: 18px;
}

.blog-sidebar__popular-link:hover {
  color: var(--accent);
}

.blog-sidebar__popular-name {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  line-height: 1.4;
  flex: 1;
}

.blog-sidebar__popular-views {
  display: flex;
  align-items: center;
  gap: 4px;
  font-family: var(--font-body);
  font-size: 11px;
  color: var(--text-muted);
  flex-shrink: 0;
  white-space: nowrap;
}

.blog-sidebar__popular-views svg {
  width: 12px;
  height: 12px;
  opacity: 0.5;
}


/* ── Rich Text (.rt) ── */
.rt h2 {
  font-family: var(--font-body);
  font-size: clamp(1.5rem, 1.2rem + 1.5vw, 2rem);
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.2;
  border-top: 1px solid var(--bg-tertiary);
  padding-top: 1.2em;
  margin-top: 1.8em;
  margin-bottom: 0.5em;
}

.rt h2:first-child {
  border-top: none;
  padding-top: 0;
  margin-top: 0;
}

.rt h3 {
  font-family: var(--font-body);
  font-size: clamp(1.2rem, 1.05rem + 0.7vw, 1.5rem);
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.25;
  margin-top: 1.5em;
  margin-bottom: 0.4em;
}

.rt p {
  font-size: clamp(15px, 14.5px + 0.15vw, 16px);
  color: var(--text-secondary);
  line-height: 1.85;
  margin-bottom: 1em;
}

.rt p:first-of-type {
  font-size: clamp(16px, 15.5px + 0.2vw, 18px);
  line-height: 1.75;
  color: var(--text-primary);
}

.rt a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: var(--accent-border-solid);
  transition: color 0.2s ease;
}

.rt a:hover { color: var(--accent-hover); }

.rt strong { font-weight: 600; color: var(--text-primary); }

.rt ul { margin: 0.75em 0; padding-left: 1.5em; list-style: disc; }
.rt ol { margin: 0.75em 0; padding-left: 1.5em; list-style: decimal; }
.rt li { margin-bottom: 0.5em; font-size: 15px; color: var(--text-secondary); line-height: 1.7; }
.rt li::marker { color: var(--accent); }

.rt blockquote {
  background: var(--accent-bg-solid);
  border-left: 4px solid var(--accent);
  border-radius: 0 12px 12px 0;
  padding: 20px 24px;
  margin: 1.2em 0;
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.1rem, 1rem + 0.5vw, 1.25rem);
  color: var(--text-primary);
  line-height: 1.6;
}

.rt img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
  margin: 1.2em 0;
}

.rt table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.2em 0;
  font-size: 14px;
}

.rt th {
  background: var(--bg-secondary);
  font-weight: 600;
  text-align: left;
  padding: 12px 16px;
  border-bottom: 2px solid var(--bg-tertiary);
  color: var(--text-primary);
}

.rt td {
  padding: 10px 16px;
  border-bottom: 1px solid var(--bg-tertiary);
  color: var(--text-secondary);
}


/* ── Section 7: CTA inline ── */
.blog-cta-inline {
  background: var(--bg-elevated);
  border: 1px solid var(--accent-border-solid);
  border-radius: 14px;
  padding: clamp(24px, 3vw, 32px);
  box-shadow: var(--shadow-sm);
  margin: 2em 0;
  text-align: center;
}

.blog-cta-inline__icon {
  width: 48px;
  height: 48px;
  margin: 0 auto 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--accent-bg-solid);
  border-radius: 12px;
}

.blog-cta-inline__icon svg {
  width: 24px;
  height: 24px;
  color: var(--accent);
}

.blog-cta-inline__heading {
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0 0 6px;
}

.blog-cta-inline__desc {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text-tertiary);
  margin: 0 0 16px;
  line-height: 1.5;
}

.blog-cta-inline__actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
}

.blog-cta-inline__btn {
  font-size: 13px;
  padding: 12px 24px;
}

.blog-cta-inline__btn svg {
  width: 16px;
  height: 16px;
}

.blog-cta-inline__btn--ghost {
  display: inline-flex;
  align-items: center;
  padding: 12px 24px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--accent);
  background: transparent;
  border: 1px solid var(--accent-border-solid);
  border-radius: 6px;
  text-decoration: none;
  transition: all 0.2s ease;
}

.blog-cta-inline__btn--ghost:hover {
  border-color: var(--accent);
  background: var(--accent-bg);
}

/* CTA type: pilne */
.blog-cta-inline[data-cta-type="pilne"] {
  background: var(--dark-bg-alt);
  border-color: var(--dark-border);
}

.blog-cta-inline[data-cta-type="pilne"] .blog-cta-inline__icon {
  background: rgba(74, 154, 106, 0.15);
}

.blog-cta-inline[data-cta-type="pilne"] .blog-cta-inline__heading {
  color: var(--emergency-text);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.blog-cta-inline[data-cta-type="pilne"] .blog-cta-inline__heading::before {
  content: '';
  width: 8px;
  height: 8px;
  background: var(--emergency-accent);
  border-radius: 50%;
  animation: pulse 2s ease-in-out infinite;
  flex-shrink: 0;
}

.blog-cta-inline[data-cta-type="pilne"] .blog-cta-inline__desc {
  color: var(--dark-text-secondary);
}

.blog-cta-inline[data-cta-type="pilne"] .blog-cta-inline__btn {
  background: var(--accent-light);
  color: var(--dark-bg);
}

.blog-cta-inline[data-cta-type="pilne"] .blog-cta-inline__btn--ghost {
  color: var(--accent-light);
  border-color: var(--dark-border);
}

.blog-cta-inline[data-cta-type="pilne"] .blog-cta-inline__btn--ghost:hover {
  border-color: var(--accent-light);
  background: rgba(74, 154, 106, 0.1);
}


/* ── Section 9: Lead Magnet ── */
.blog-lead-magnet {
  background: var(--bg-secondary);
  border-radius: 14px;
  padding: 24px;
  margin: 2em 0;
  text-align: center;
}

.blog-lead-magnet[hidden] { display: none; }

.blog-lead-magnet__icon {
  width: 40px;
  height: 40px;
  margin: 0 auto 10px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.blog-lead-magnet__icon svg {
  width: 24px;
  height: 24px;
  color: var(--accent);
}

.blog-lead-magnet__heading {
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0 0 4px;
}

.blog-lead-magnet__title {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text-secondary);
  margin: 0 0 16px;
}

.blog-lead-magnet__form {
  max-width: 420px;
  margin: 0 auto;
}

.blog-lead-magnet__fields {
  display: flex;
  gap: 8px;
}

.blog-lead-magnet__input {
  flex: 1;
  padding: 12px 16px;
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text-primary);
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 6px;
  outline: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.blog-lead-magnet__input::placeholder { color: var(--text-muted); }

.blog-lead-magnet__input:focus {
  border-color: var(--accent);
  box-shadow: var(--shadow-focus);
}

.blog-lead-magnet__submit {
  white-space: nowrap;
  font-size: 13px;
  padding: 12px 20px;
}

.blog-lead-magnet__disclaimer {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  margin: 10px 0 0;
  font-family: var(--font-body);
  font-size: 11px;
  color: var(--text-muted);
}

.blog-lead-magnet__disclaimer svg {
  width: 12px;
  height: 12px;
  opacity: 0.5;
  flex-shrink: 0;
}

/* Lead Magnet: download variant */
.blog-lead-magnet__download {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}

.blog-lead-magnet__file-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text-secondary);
  margin: 0;
}

.blog-lead-magnet__file-label svg {
  width: 16px;
  height: 16px;
  color: var(--accent);
  flex-shrink: 0;
}

.blog-lead-magnet__download .blog-lead-magnet__submit {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
}

.blog-lead-magnet__download .blog-lead-magnet__submit svg {
  width: 16px;
  height: 16px;
}


/* ── Responsive: Content + Sidebar ── */
@media (max-width: 960px) {
  .blog-layout__inner {
    grid-template-columns: 1fr;
  }

  .blog-layout__content {
    max-width: 100%;
  }

  .blog-sidebar {
    position: static;
    display: none;
  }
}

@media (max-width: 600px) {
  .blog-cta-inline__actions {
    flex-direction: column;
  }

  .blog-cta-inline__btn,
  .blog-cta-inline__btn--ghost {
    width: 100%;
    justify-content: center;
    min-height: 48px;
  }

  .blog-lead-magnet__fields {
    flex-direction: column;
  }

  .blog-lead-magnet__submit,
  .blog-lead-magnet__download .blog-lead-magnet__submit {
    width: 100%;
    min-height: 48px;
    justify-content: center;
  }
}


/* ── Section 11: Social Proof ── */
.blog-social-proof {
  background: var(--bg-secondary);
  padding: clamp(48px, 5vw, 72px) 0;
}

.blog-social-proof[hidden] { display: none; }

.blog-social-proof__inner {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 clamp(20px, 12px + 3vw, 96px);
  display: grid;
  grid-template-columns: 65% 35%;
  gap: clamp(32px, 4vw, 56px);
  align-items: center;
}

/* Quote column */
.blog-social-proof__quote {
  position: relative;
}

.blog-social-proof__mark {
  display: block;
  font-family: var(--font-display);
  font-size: 48px;
  color: var(--accent);
  opacity: 0.3;
  line-height: 1;
  margin-bottom: -8px;
}

.blog-social-proof__text {
  font-family: var(--font-display);
  font-size: clamp(1.1rem, 1rem + 0.5vw, 1.35rem);
  font-style: italic;
  color: var(--text-primary);
  line-height: 1.6;
  margin: 0 0 12px;
}

.blog-social-proof__cite {
  font-family: var(--font-body);
  font-size: 13px;
  font-style: normal;
  color: var(--text-muted);
}

/* Stats column */
.blog-social-proof__stats {
  padding-left: clamp(24px, 3vw, 40px);
  border-left: 1px solid var(--bg-tertiary);
}

.blog-social-proof__stat-main {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.blog-social-proof__stat-number {
  font-family: var(--font-display);
  font-size: 40px;
  font-weight: 700;
  color: var(--accent);
  line-height: 1;
}

.blog-social-proof__stat-label {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text-muted);
  line-height: 1.4;
}

.blog-social-proof__stat-sep {
  border: none;
  border-top: 1px solid var(--bg-tertiary);
  margin: 16px 0;
}

.blog-social-proof__stat-google {
  display: flex;
  align-items: center;
  gap: 4px;
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text-muted);
}

.blog-social-proof__stat-google svg {
  width: 12px;
  height: 12px;
  fill: var(--accent);
}

@media (max-width: 700px) {
  .blog-social-proof__inner {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .blog-social-proof__stats {
    padding-left: 0;
    border-left: none;
    border-top: 1px solid var(--bg-tertiary);
    padding-top: 24px;
  }
}


/* ── Section 12: Bridge ── */
.blog-bridge {
  background: var(--bg-primary);
  padding: 32px 0;
}

.blog-bridge__inner {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 clamp(20px, 12px + 3vw, 96px);
}

.blog-bridge__card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: clamp(20px, 3vw, 32px);
  padding: clamp(24px, 3vw, 32px);
  background: var(--bg-elevated);
  border: 1px solid var(--bg-tertiary);
  border-radius: 14px;
  text-decoration: none;
  color: inherit;
  transition: border-color 0.25s ease, box-shadow 0.25s ease;
}

.blog-bridge__card:hover {
  border-color: var(--accent-border-solid);
  box-shadow: var(--shadow-md);
}

.blog-bridge__left {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  min-width: 0;
}

.blog-bridge__icon {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--accent-bg-solid);
  border-radius: 10px;
  flex-shrink: 0;
}

.blog-bridge__icon svg {
  width: 22px;
  height: 22px;
  color: var(--accent);
}

.blog-bridge__text {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.blog-bridge__label {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--accent);
}

.blog-bridge__title {
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.3;
}

.blog-bridge__desc {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text-tertiary);
  line-height: 1.5;
  margin-top: 2px;
}

.blog-bridge__right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
  flex-shrink: 0;
}

.blog-bridge__cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  background: var(--accent);
  color: #fff;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  border-radius: 6px;
  white-space: nowrap;
  transition: background 0.2s ease;
}

.blog-bridge__card:hover .blog-bridge__cta {
  background: var(--accent-hover);
}

.blog-bridge__arrow {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  transition: transform 0.2s ease;
}

.blog-bridge__card:hover .blog-bridge__arrow {
  transform: translateX(3px);
}

.blog-bridge__stat {
  font-family: var(--font-body);
  font-size: 11px;
  color: var(--text-muted);
  white-space: nowrap;
}

@media (max-width: 700px) {
  .blog-bridge__card {
    flex-direction: column;
    align-items: stretch;
  }

  .blog-bridge__right {
    align-items: stretch;
    border-top: 1px solid var(--bg-tertiary);
    padding-top: 16px;
  }

  .blog-bridge__cta {
    justify-content: center;
    min-height: 48px;
  }

  .blog-bridge__stat {
    text-align: center;
  }
}


/* ── Section 13: Blog FAQ ── */
.blog-faq {
  background: var(--bg-secondary);
  padding: clamp(48px, 5vw, 72px) 0;
}

.blog-faq[hidden] { display: none; }

.blog-faq__inner {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 clamp(20px, 12px + 3vw, 96px);
}

.blog-faq__eyebrow {
  display: block;
  text-align: center;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 24px;
}

/* Reuses .faq__accordion, .faq__item, .faq__question,
   .faq__icon, .faq__answer from the main FAQ styles.
   Only override font-size for the blog context. */
.blog-faq .faq__question {
  font-size: 15px;
  padding: 20px 0;
}

.blog-faq .faq__answer-inner p {
  font-size: 14px;
}


/* ── Section 14: Powiązane artykuły ── */
.blog-related {
  background: var(--bg-primary);
  padding: clamp(48px, 5vw, 72px) 0;
}

.blog-related__inner {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 clamp(20px, 12px + 3vw, 96px);
}

.blog-related__header {
  text-align: center;
  margin-bottom: 32px;
}

.blog-related__eyebrow {
  display: block;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 8px;
}

.blog-related__headline {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 1.2rem + 1.5vw, 2rem);
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.2;
}

.blog-related__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}

.blog-related__cta {
  text-align: center;
  margin-top: 32px;
}

.blog-related__cta-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  transition: gap 0.2s ease;
}

.blog-related__cta-link:hover {
  gap: 12px;
}

.blog-related__cta-link svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  stroke-width: 2;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

@media (max-width: 600px) {
  .blog-related__grid {
    grid-template-columns: 1fr;
  }
}


/* ── Slide-in CTA ── */
.slide-cta {
  position: fixed;
  right: 24px;
  bottom: 96px;
  z-index: 900;
  width: 360px;
  background: #1A1A1A;
  border: 1px solid rgba(220, 60, 60, 0.2);
  border-radius: 16px;
  padding: 24px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.45), 0 4px 20px rgba(0, 0, 0, 0.25);
  transform: translateY(calc(100% + 48px));
  opacity: 0;
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1),
              opacity 0.3s ease;
  pointer-events: none;
  overflow: hidden;
}

/* Red accent glow at top */
.slide-cta::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, #DC3C3C, #E85555, #DC3C3C);
}

.slide-cta:not(.is-visible):not(.is-dismissing) {
  transform: translateY(calc(100% + 48px));
  opacity: 0;
  pointer-events: none;
}

.slide-cta.is-visible {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}

.slide-cta.is-dismissing {
  transform: translateY(calc(100% + 48px));
  opacity: 0;
  pointer-events: none;
}

/* Close button */
.slide-cta__close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  cursor: pointer;
  border-radius: 50%;
  transition: background 0.2s ease;
}

.slide-cta__close:hover {
  background: rgba(255, 255, 255, 0.08);
}

.slide-cta__close svg {
  width: 16px;
  height: 16px;
  stroke: rgba(255, 255, 255, 0.35);
  stroke-width: 2;
  stroke-linecap: round;
  fill: none;
}

/* Desktop content */
.slide-cta__desktop {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.slide-cta__badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: #DC3C3C;
  margin-bottom: 12px;
}

.slide-cta__pulse {
  width: 6px;
  height: 6px;
  background: #DC3C3C;
  border-radius: 50%;
  position: relative;
  flex-shrink: 0;
}

.slide-cta__pulse::after {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  background: #DC3C3C;
  opacity: 0;
  animation: pulse 2s ease-in-out infinite;
}

.slide-cta__heading {
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 700;
  color: #F8F6F2;
  margin: 0 0 14px;
  padding-right: 28px;
  line-height: 1.35;
}

.slide-cta__phone-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  background: rgba(220, 60, 60, 0.08);
  border: 1px solid rgba(220, 60, 60, 0.15);
  border-radius: 10px;
  margin-bottom: 12px;
  transition: background 0.2s ease;
}

.slide-cta__phone-row:hover {
  background: rgba(220, 60, 60, 0.14);
}

.slide-cta__phone-icon {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #DC3C3C;
  border-radius: 8px;
  flex-shrink: 0;
}

.slide-cta__phone-icon svg {
  width: 16px;
  height: 16px;
  color: #fff;
}

.slide-cta__phone {
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 700;
  color: #F8F6F2;
  text-decoration: none;
  letter-spacing: 0.5px;
}

.slide-cta__meta {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-body);
  font-size: 11px;
  color: rgba(255, 255, 255, 0.4);
}

.slide-cta__meta-sep {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.2);
}

/* Mobile content — hidden on desktop */
.slide-cta__mobile { display: none; }

/* Overlay — mobile only */
.slide-cta__overlay { display: none; }

@media (max-width: 768px) {
  .slide-cta {
    right: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    max-height: 35vh;
    border-radius: 16px 16px 0 0;
    border: none;
    border-top: 2px solid #DC3C3C;
    padding: 16px 20px 28px;
  }

  .slide-cta::before { display: none; }

  .slide-cta:not(.is-visible):not(.is-dismissing) {
    transform: translateY(100%);
  }

  .slide-cta.is-visible {
    transform: translateY(0);
  }

  .slide-cta.is-dismissing {
    transform: translateY(100%);
  }

  .slide-cta__desktop { display: none; }
  .slide-cta__close { display: none; }

  .slide-cta__mobile {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
  }

  .slide-cta__handle {
    width: 36px;
    height: 4px;
    border-radius: 2px;
    background: rgba(255, 255, 255, 0.15);
    margin-bottom: 4px;
  }

  .slide-cta__mobile-btn {
    width: 100%;
    min-height: 52px;
    justify-content: center;
    background: #DC3C3C;
    font-size: 15px;
  }

  .slide-cta__mobile-btn:hover {
    background: #C53030;
  }

  .slide-cta__mobile-btn svg {
    width: 18px;
    height: 18px;
  }

  .slide-cta__mobile .slide-cta__avail {
    text-align: center;
    font-family: var(--font-body);
    font-size: 11px;
    color: rgba(255, 255, 255, 0.4);
  }

  /* Overlay */
  .slide-cta__overlay {
    position: fixed;
    inset: 0;
    z-index: 899;
    background: rgba(0, 0, 0, 0.4);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
  }

  .slide-cta__overlay:not(.is-visible) {
    opacity: 0;
    pointer-events: none;
  }

  .slide-cta__overlay.is-visible {
    opacity: 1;
    pointer-events: auto;
  }
}

@media (prefers-reduced-motion: reduce) {
  .slide-cta { transition: none; }
  .slide-cta__overlay { transition: none; }
}


/* ── Exit Intent Popup ── */
.exit-popup[hidden] { display: none; }

.exit-popup {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-3);
}

.exit-popup__overlay {
  position: absolute;
  inset: 0;
  background: rgba(13, 13, 13, 0.6);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  animation: exitFadeIn 0.3s ease both;
}

.exit-popup__modal {
  position: relative;
  width: 100%;
  max-width: 440px;
  background: var(--bg-elevated);
  border-radius: 20px;
  box-shadow: 0 24px 80px rgba(13, 13, 13, 0.18), 0 8px 24px rgba(13, 13, 13, 0.1);
  overflow: hidden;
  animation: exitScaleIn 0.35s cubic-bezier(0.16, 1, 0.3, 1) both;
}

.exit-popup__close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-secondary);
  border: none;
  border-radius: 50%;
  cursor: pointer;
  transition: background 0.2s ease;
  z-index: 1;
}

.exit-popup__close:hover {
  background: var(--bg-tertiary);
}

.exit-popup__close svg {
  width: 16px;
  height: 16px;
  stroke: var(--text-tertiary);
  stroke-width: 2;
  stroke-linecap: round;
  fill: none;
}

.exit-popup__body {
  padding: 40px 32px 32px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.exit-popup__icon {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--accent-bg-solid);
  border-radius: 16px;
  margin-bottom: var(--space-3);
}

.exit-popup__icon svg {
  width: 28px;
  height: 28px;
  color: var(--accent);
}

.exit-popup__heading {
  font-family: var(--font-display);
  font-size: clamp(24px, 3.5vw, 30px);
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.2;
  margin: 0 0 4px;
}

.exit-popup__sub {
  font-family: var(--font-display);
  font-size: clamp(20px, 2.8vw, 24px);
  font-weight: 500;
  color: var(--accent);
  line-height: 1.3;
  margin: 0 0 var(--space-2);
}

.exit-popup__desc {
  font-size: 14px;
  color: var(--text-tertiary);
  line-height: 1.6;
  margin: 0 0 var(--space-3);
  max-width: 340px;
}

.exit-popup__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  width: 100%;
  padding: 14px 24px;
  border-radius: 12px;
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 600;
  text-decoration: none;
  transition: background 0.2s ease, transform 0.15s ease;
}

.exit-popup__btn:active {
  transform: scale(0.98);
}

.exit-popup__btn svg {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

.exit-popup__btn--phone {
  background: var(--accent);
  color: var(--text-inverse);
  margin-bottom: 10px;
}

.exit-popup__btn--phone:hover {
  background: var(--accent-hover);
}

.exit-popup__btn--phone svg {
  color: var(--text-inverse);
}

.exit-popup__btn-content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  line-height: 1.3;
}

.exit-popup__btn-content strong {
  font-size: 16px;
  letter-spacing: 0.3px;
}

.exit-popup__btn-content small {
  font-size: 12px;
  font-weight: 400;
  opacity: 0.8;
}

.exit-popup__btn--meeting {
  background: var(--accent-bg-solid);
  color: var(--accent);
  border: 1px solid var(--accent-border-solid);
  margin-bottom: var(--space-3);
}

.exit-popup__btn--meeting:hover {
  background: var(--accent-bg);
  border-color: var(--accent);
}

.exit-popup__proof {
  display: flex;
  align-items: center;
  gap: 8px;
  padding-top: var(--space-2);
  border-top: 1px solid var(--border);
  width: 100%;
  justify-content: center;
}

.exit-popup__stars {
  display: flex;
  gap: 2px;
}

.exit-popup__stars svg {
  width: 14px;
  height: 14px;
  color: #E5A100;
}

.exit-popup__rating {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-tertiary);
}

/* Exit popup animations */
@keyframes exitFadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes exitScaleIn {
  from {
    opacity: 0;
    transform: scale(0.92) translateY(12px);
  }
  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

/* Exit popup dismissing state */
.exit-popup.is-dismissing .exit-popup__overlay {
  animation: exitFadeOut 0.25s ease both;
}

.exit-popup.is-dismissing .exit-popup__modal {
  animation: exitScaleOut 0.25s ease both;
}

@keyframes exitFadeOut {
  from { opacity: 1; }
  to { opacity: 0; }
}

@keyframes exitScaleOut {
  from {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
  to {
    opacity: 0;
    transform: scale(0.95) translateY(8px);
  }
}

/* Exit popup — mobile */
@media (max-width: 600px) {
  .exit-popup {
    align-items: flex-end;
    padding: 0;
  }

  .exit-popup__modal {
    max-width: 100%;
    border-radius: 20px 20px 0 0;
    animation: exitSlideUp 0.35s cubic-bezier(0.16, 1, 0.3, 1) both;
  }

  .exit-popup__body {
    padding: 32px 24px 28px;
  }

  .exit-popup.is-dismissing .exit-popup__modal {
    animation: exitSlideDown 0.25s ease both;
  }

  @keyframes exitSlideUp {
    from {
      opacity: 0;
      transform: translateY(100%);
    }
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }

  @keyframes exitSlideDown {
    from {
      opacity: 1;
      transform: translateY(0);
    }
    to {
      opacity: 0;
      transform: translateY(100%);
    }
  }
}

@media (prefers-reduced-motion: reduce) {
  .exit-popup__overlay,
  .exit-popup__modal,
  .exit-popup.is-dismissing .exit-popup__overlay,
  .exit-popup.is-dismissing .exit-popup__modal {
    animation: none;
  }
}

/* ============================================================
   LARGE SCREENS — reduce excessive spacing
   ============================================================ */
@media (min-width: 1600px) {

  /* ── Hero sections — cap height & padding ── */
  .hh-hero {
    min-height: min(90vh, 800px);
    padding: 140px 0 48px;
  }
  .cat-hero {
    min-height: min(92vh, 820px);
    padding: 140px 0 56px;
  }
  .a24-hero {
    min-height: min(90vh, 800px);
    padding: 140px 0 56px;
  }
  .a24s-hero {
    min-height: min(90vh, 800px);
  }
  .a24s-hero > .container {
    padding-top: 180px;
    padding-bottom: 56px;
  }
  .sp-hero { padding: 140px 0 40px; }
  .oka-hero {
    min-height: min(90vh, 800px);
    padding: 140px 0 56px;
  }
  .kt-hero { padding: 120px 0 80px; }
  .cennik-hero { padding: 140px 0 56px; }
  .pro-section { padding: 120px 0 64px; }
  .cost-bottom-cta { padding: 120px 0 64px; }

  /* ── Front page sections ── */
  .vs { padding: 24px 0; }
  .stabs { padding: 80px 0; }
  .ecta { padding: 56px 0; }
  .why { padding: 80px 0; }
  .about { padding-bottom: 80px; }
  .about__grid { gap: 64px; }
  .cases { padding: 80px 0; }
  .reviews { padding: 64px 0; }
  .media { padding-bottom: 72px; }
  .cpanel { padding: 80px 0; }
  .cpanel__emergency { padding: 56px 0; }
  .knowledge { padding: 80px 0; }
  .faq { padding: 72px 0; }
  .fcta { padding: 56px 0; }
  .fcta-follow { padding: 80px 0; }

  /* ── Subpage sections ── */
  .orbit-section { padding: 56px 0; }
  .expert { padding: 36px 0 80px; }
  .a24-timeline { padding: 80px 0; }
  .e24-timeline-section { padding: 56px 0; }
  .oka-story { padding: 80px 0; }
  .oka-team { padding: 80px 0; }
  .oka-collab { padding: 80px 0; }
  .kt-contact { padding: 72px 0; }
  .pricing { padding: 80px 0; }
  .why-hourly { padding: 80px 0; }
  .cost-factors { padding: 80px 0; }
  .cost-cta { padding: 80px 0; }
}

/* ============================================================
   HERO SPLIT LAYOUT (kontakt)
   ============================================================ */

.kt-hero--split {
  text-align: left;
}

.kt-hero__split-grid {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
  align-items: start;
}

.kt-hero--split .kt-hero__inner {
  max-width: none;
  margin: 0;
}

.kt-hero--split .kt-hero__stats {
  justify-content: flex-start;
}

.kt-hero--split .kt-hero__inner {
  position: sticky;
  top: 100px;
  align-self: start;
}

.kt-hero--split .kt-hero__lead {
  margin-left: 0;
  margin-right: 0;
}

.kt-hero--split .kt-hero__quick {
  justify-content: flex-start;
}

.kt-hero--split .kt-hero__availability {
  justify-content: flex-start;
}

.kt-hero--split .kt-hero__social-proof {
  justify-content: flex-start;
}

.kt-hero__form-col {
  position: relative;
}

.kt-hero__form-col .kt-form-card {
  position: sticky;
  top: 100px;
}

@media (max-width: 991px) {
  .kt-hero__split-grid {
    grid-template-columns: 1fr;
    gap: var(--space-5);
  }
  .kt-hero--split {
    text-align: center;
  }
  .kt-hero--split .kt-hero__inner {
    max-width: 600px;
    margin: 0 auto;
    position: static;
  }
  .kt-hero--split .kt-hero__lead {
    margin-left: auto;
    margin-right: auto;
  }
  .kt-hero--split .kt-hero__quick {
    justify-content: center;
    flex-wrap: wrap;
  }
  .kt-hero--split .kt-hero__availability {
    justify-content: center;
  }
  .kt-hero--split .kt-hero__social-proof {
    justify-content: center;
  }
  .kt-hero--split .kt-hero__stats {
    justify-content: center;
  }
  .kt-hero--split .kt-hero__trust-badges {
    justify-content: center;
  }
  .kt-hero--split .kt-hero__location {
    justify-content: center;
  }
  .kt-hero__form-col .kt-form-card {
    position: static;
  }
}

/* Hero split — trust badges */
.kt-hero__trust-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 20px;
  margin-top: var(--space-3);
}

.kt-hero__trust-badge {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--dark-text-secondary, rgba(255,255,255,0.75));
}

.kt-hero__trust-badge svg {
  flex-shrink: 0;
  stroke: var(--accent-light);
}

.kt-hero__trust-badge strong {
  color: var(--dark-text, #fff);
}

/* Hero split — location */
.kt-hero__location {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: var(--space-3);
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--dark-text-muted, rgba(255,255,255,0.5));
}

.kt-hero__location svg {
  flex-shrink: 0;
  stroke: var(--accent-light);
  opacity: 0.7;
}


/* ============================================================
   CALENDAR CARD IN CONTACT SECTION
   ============================================================ */

.kt-contact__calendar-card {
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}

.kt-contact__calendar-header {
  padding: var(--space-3) var(--space-4) 0;
}

.kt-contact__calendar-title {
  font-family: var(--font-display);
  font-size: clamp(1.3rem, 2.5vw, 1.6rem);
  font-weight: 700;
  color: var(--text-primary);
  margin: 4px 0 6px;
}

.kt-contact__calendar-sub {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text-tertiary);
  line-height: 1.55;
  margin: 0;
}

.kt-contact__calendar-embed {
  padding: var(--space-2) var(--space-3) var(--space-3);
}

.kt-contact__calendar-embed .zencal-embed {
  min-height: 480px;
}

@media (max-width: 768px) {
  .kt-contact__calendar-header {
    padding: var(--space-2) var(--space-3) 0;
  }
  .kt-contact__calendar-embed {
    padding: var(--space-1) var(--space-2) var(--space-2);
  }
  .kt-contact__calendar-embed .zencal-embed {
    min-height: 400px;
  }
}

/* ============================================================
   ZENCAL CALENDAR SECTION (standalone — kept for reuse)
   ============================================================ */

.kt-calendar {
  padding: clamp(64px, 8vh, 100px) 0;
  background: var(--bg-secondary);
}

.kt-calendar__header {
  text-align: center;
  margin-bottom: var(--space-6);
}

.kt-calendar__eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--accent);
  margin-bottom: var(--space-1);
}

.kt-calendar__headline {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 700;
  color: var(--text-primary);
  margin: 0 0 8px;
}

.kt-calendar__sub {
  font-family: var(--font-body);
  font-size: 15px;
  color: var(--text-tertiary);
  margin: 0;
}

.kt-calendar__embed {
  max-width: 800px;
  margin: 0 auto;
  background: var(--bg-primary);
  border-radius: 16px;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-lg);
  padding: var(--space-3);
  overflow: hidden;
}

.kt-calendar__embed .zencal-embed {
  min-height: 500px;
}

@media (max-width: 768px) {
  .kt-calendar__embed {
    padding: var(--space-2);
    border-radius: 12px;
  }
  .kt-calendar__embed .zencal-embed {
    min-height: 400px;
  }
}

/* ============================================================
   CONTACT FORM 7 – OVERRIDE TO MATCH EXISTING DESIGN
   ============================================================ */

/* CF7 wraps each field in .wpcf7-form-control-wrap – make it block */
.wpcf7-form-control-wrap {
  display: block;
  width: 100%;
}

/* CF7 form inherits kt-form class via html_class */
.wpcf7 .wpcf7-form.kt-form {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.wpcf7 .wpcf7-form p,
.wpcf7 .wpcf7-form .kt-form__group p,
.wpcf7 .wpcf7-form .kt-form__select-wrap p,
.wpcf7 .wpcf7-form .kt-form__rodo-row p {
  margin: 0 !important;
  padding: 0 !important;
}
.wpcf7 .wpcf7-form .kt-form__group {
  margin: 0;
  padding: 0;
  gap: 2px;
}
.wpcf7 .wpcf7-form br {
  display: none !important;
}
.wpcf7 .wpcf7-form .wpcf7-form-control-wrap {
  margin: 0;
  padding: 0;
}
.wpcf7 .wpcf7-form .kt-form__label {
  margin: 0;
}
.wpcf7 .wpcf7-form fieldset {
  margin: 0;
  padding: 0;
  border: none;
}

/* CF7 inputs/selects/textareas inherit our classes via class: shortcode attr,
   but CF7 also adds .wpcf7-form-control – ensure no conflicts */
.wpcf7 .wpcf7-form-control.kt-form__input,
.wpcf7 .wpcf7-form-control.kt-form__select,
.wpcf7 .wpcf7-form-control.kt-form__textarea {
  font-family: var(--font-body);
  font-size: 15px;
  color: var(--text-primary);
  background: var(--bg-primary);
  border: 1.5px solid var(--border);
  border-radius: 8px;
  padding: 12px 14px;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
  outline: none;
  width: 100%;
  box-sizing: border-box;
}
.wpcf7 .wpcf7-form-control.kt-form__input:focus,
.wpcf7 .wpcf7-form-control.kt-form__select:focus,
.wpcf7 .wpcf7-form-control.kt-form__textarea:focus {
  border-color: var(--accent);
  box-shadow: var(--shadow-focus);
  background: var(--bg-elevated);
}

/* CF7 select: match our appearance:none + chevron setup */
.wpcf7 .wpcf7-form-control.kt-form__select {
  appearance: none;
  padding-right: 40px;
  cursor: pointer;
}

/* CF7 textarea */
.wpcf7 .wpcf7-form-control.kt-form__textarea {
  resize: vertical;
  min-height: 120px;
  max-height: 300px;
}

/* CF7 submit button – match kt-form__submit */
.wpcf7 .wpcf7-form-control.wpcf7-submit.kt-form__submit {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 16px 32px;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 10px;
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.2s ease, transform 0.25s ease, box-shadow 0.25s ease;
  margin-top: var(--space-1);
  overflow: hidden;
}
.wpcf7 .wpcf7-form-control.wpcf7-submit.kt-form__submit:hover:not(:disabled) {
  background: var(--accent-hover);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(46, 107, 71, 0.25);
}
.wpcf7 .wpcf7-form-control.wpcf7-submit.kt-form__submit:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

/* CF7 spinner (loading indicator) */
.wpcf7 .wpcf7-spinner {
  margin-left: 8px;
}

/* CF7 validation error per-field */
.wpcf7 .wpcf7-not-valid {
  border-color: #C0392B !important;
  box-shadow: 0 0 0 3px rgba(192, 57, 43, 0.1) !important;
}
.wpcf7 .wpcf7-not-valid-tip {
  color: #C0392B;
  font-family: var(--font-body);
  font-size: 12px;
  margin-top: 4px;
  display: block;
}

/* CF7 response output (success/error message) */
.wpcf7 .wpcf7-response-output {
  border: none !important;
  padding: 16px;
  border-radius: 10px;
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.5;
  margin: var(--space-1) 0 0;
}
.wpcf7 form.sent .wpcf7-response-output {
  background: var(--accent-bg-solid, rgba(3, 81, 67, 0.08));
  color: var(--accent);
  border-left: 4px solid var(--accent) !important;
}
.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output {
  background: rgba(192, 57, 43, 0.08);
  color: #C0392B;
  border-left: 4px solid #C0392B !important;
}
.wpcf7 form.invalid .wpcf7-response-output {
  background: rgba(192, 57, 43, 0.06);
  color: #C0392B;
  border-left: 4px solid #C0392B !important;
}

/* CF7 acceptance (RODO checkbox) */
.kt-form__rodo-row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
}
.kt-form__rodo-row .wpcf7-form-control-wrap {
  flex: 0 0 20px;
  display: flex;
  width: 20px;
}
.kt-form__rodo-row .wpcf7-form-control.wpcf7-acceptance {
  flex-shrink: 0;
  margin: 0;
  padding: 0;
}
.kt-form__rodo-row .wpcf7-form-control.wpcf7-acceptance .wpcf7-list-item {
  margin: 0;
}
.kt-form__rodo-row .wpcf7-form-control.wpcf7-acceptance .wpcf7-list-item label {
  cursor: pointer;
}
.kt-form__rodo-row .wpcf7-acceptance input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 20px;
  height: 20px;
  min-width: 20px;
  min-height: 20px;
  border: 1.5px solid var(--border);
  border-radius: 5px;
  background: var(--bg-primary);
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease;
  margin: 0;
  display: block;
  position: relative;
  flex-shrink: 0;
}
.kt-form__rodo-row .wpcf7-acceptance input[type="checkbox"]:checked {
  background: var(--accent);
  border-color: var(--accent);
}
.kt-form__rodo-row .wpcf7-acceptance input[type="checkbox"]:checked::after {
  content: '';
  position: absolute;
  top: 3px;
  left: 6px;
  width: 5px;
  height: 10px;
  border: solid #fff;
  border-width: 0 2.5px 2.5px 0;
  transform: rotate(45deg);
}
.kt-form__rodo-row .wpcf7-acceptance input[type="checkbox"]:focus-visible {
  box-shadow: var(--shadow-focus);
}
.kt-form__rodo-row > .kt-form__checkbox-text {
  flex: 1;
}

/* CF7 callback form in sidebar */
.sidebar-form .wpcf7-form-control-wrap {
  display: block;
  width: 100%;
}
.sidebar-form .wpcf7 .wpcf7-response-output {
  font-size: 13px;
  padding: 10px;
  margin: 8px 0 0;
}
.sidebar-form .wpcf7 .wpcf7-response-output[aria-hidden="true"] {
  display: none;
}


/* ============================================================
   PRZESTĘPCZOŚĆ ZORGANIZOWANA — FLAGSHIP PAGE (oz- prefix)
   ============================================================ */

/* ── PRZESTĘPCZOŚĆ ZORGANIZOWANA — PAGE COLOR PALETTE ── */
.oz-page {
  /* Hero-specific tokens */
  --oz: #C87A2A;
  --oz-light: #E09840;
  --oz-text: #8A6A3A;
  --oz-text-dim: #5A4A2A;
  --oz-text-pale: #3A3020;
  --oz-bg: #0A0806;
  --oz-bg-card: #0D0A07;
  --oz-border: rgba(200,122,42,.08);
  --oz-border-strong: rgba(200,122,42,.15);
  --oz-glow: rgba(200,122,42,.06);

  /* Override global design system — all oz- sections inherit amber */
  --accent: #C87A2A;
  --accent-hover: #E09840;
  --accent-light: #D4922E;
  --accent-bg: rgba(200,122,42,.06);
  --accent-border: rgba(200,122,42,.12);
  --accent-bg-solid: #1E160D;
  --accent-border-solid: #4D3A1E;
}

/* ── S1: HERO — WIRE ROOM / PODSŁUCH ── */
.oz-hero {
  position: relative;
  background: var(--oz-bg);
  overflow: hidden;
  height: 100vh;
  display: flex;
  align-items: center;
}
.oz-hero__topline {
  position: absolute; top: 0; left: 0; right: 0; height: 2px; z-index: 4;
  background: linear-gradient(90deg, var(--oz) 0%, transparent 40%);
}

/* ── Hero text: replicate .container left padding, right half reserved for wire ── */
.oz-hero__text {
  position: relative; z-index: 2;
  width: 50%;
  display: flex; flex-direction: column; justify-content: center;
  padding-top: clamp(140px, 14vw, 180px);
  padding-bottom: clamp(40px, 4vw, 60px);
  padding-left: max(clamp(20px, 12px + 3vw, 96px), (100vw - 1440px) / 2 + clamp(20px, 12px + 3vw, 96px));
  padding-right: clamp(20px, 3vw, 48px);
}

/* ── Wire panel: absolute background, flush right, clipped, no interaction ── */
.oz-hero__wire {
  position: absolute;
  top: 0; right: 0;
  width: 50%; height: 100%;
  overflow: hidden;
  background: var(--oz-bg-card);
  border-left: 1px solid var(--oz-glow);
  z-index: 1;
  pointer-events: none;
  user-select: none;
  -webkit-user-select: none;
}
/* ── Dashboard layout: sidebar + main ── */
.oz-dash {
  display: grid;
  grid-template-columns: 200px 1fr;
  width: 100%; height: 100%;
}

/* Sidebar: file tabs + profiles */
.oz-dash__sidebar {
  border-right: 1px solid var(--oz-glow);
  padding: 16px 14px;
  display: flex; flex-direction: column; gap: 8px;
  overflow-y: auto; overflow-x: hidden;
  background: rgba(0,0,0,.2);
  scrollbar-width: thin;
  scrollbar-color: var(--oz-border) transparent;
}

/* Case file tabs */
.oz-dash__files { display: flex; flex-direction: column; gap: 6px; }
.oz-dash__file {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 10px; border-radius: 8px;
  font: 400 10px/1.3 'Space Grotesk', sans-serif;
  color: rgba(200,122,42,.3);
  border: 1px solid transparent;
  transition: border-color .2s, color .2s;
}
.oz-dash__file--active {
  border-color: var(--oz-border-strong);
  background: rgba(200,122,42,.04);
  color: rgba(200,122,42,.6);
}
.oz-dash__file-icon { font-size: 14px; flex-shrink: 0; filter: grayscale(1) brightness(.6); }
.oz-dash__file--active .oz-dash__file-icon { filter: none; }
.oz-dash__file-info { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.oz-dash__file-name { font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.oz-dash__file-meta { font-size: 9px; opacity: .6; }

/* Suspect profiles */
.oz-dash__profiles { display: flex; flex-direction: column; gap: 4px; flex: 1; }
/* Section labels in sidebar */
.oz-dash__section-label {
  font: 700 8px/1 'Space Grotesk', sans-serif;
  text-transform: uppercase; letter-spacing: 2px;
  color: rgba(200,122,42,.2);
  padding: 12px 0 6px;
  border-bottom: 1px solid rgba(200,122,42,.04);
  margin-bottom: 6px;
}
.oz-dash__section-label:first-child { padding-top: 0; }

.oz-dash__profile {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px; border-radius: 8px;
  border: 1px solid rgba(200,122,42,.05);
}
.oz-dash__profile--accent {
  border-color: var(--oz-border-strong);
  background: rgba(200,122,42,.04);
}

.oz-dash__avatar {
  width: 32px; height: 32px; border-radius: 50%; flex-shrink: 0;
  background: var(--oz-border);
  border: 1px solid var(--oz-border);
  display: flex; align-items: center; justify-content: center;
  font: 600 11px/1 'Space Grotesk', sans-serif;
  color: rgba(200,122,42,.3);
}
.oz-dash__avatar--accent {
  background: var(--oz-border-strong);
  border-color: rgba(200,122,42,.3);
  color: var(--oz);
}

.oz-dash__profile-data {
  display: flex; flex-direction: column; gap: 2px; min-width: 0;
  font: 400 10px/1.3 'Space Grotesk', sans-serif;
}
.oz-dash__redacted { color: var(--oz-border-strong); font-size: 9px; }
.oz-dash__profile-role { color: rgba(200,122,42,.35); font-size: 9px; text-transform: uppercase; letter-spacing: 1px; }
.oz-dash__profile-status {
  font-size: 8px; font-weight: 600; text-transform: uppercase; letter-spacing: 1px;
  color: rgba(200,80,80,.5);
}
.oz-dash__profile-status--pending { color: rgba(200,122,42,.7); }
.oz-dash__profile--accent .oz-wire-blink { font-size: 10px; }

/* Profile alias tag */
.oz-dash__profile-alias {
  font: 600 7px/1 'Space Grotesk', sans-serif;
  text-transform: uppercase; letter-spacing: 1.5px;
  color: rgba(200,122,42,.2);
}
.oz-dash__profile-alias--accent { color: rgba(200,122,42,.6); }

/* Mini stats in sidebar */
.oz-dash__stats-mini {
  display: grid; grid-template-columns: 1fr 1fr; gap: 6px;
  margin-top: 4px;
}
.oz-dash__stat-mini {
  padding: 8px; border-radius: 6px;
  background: rgba(200,122,42,.03);
  border: 1px solid rgba(200,122,42,.04);
}
.oz-dash__stat-mini-val {
  display: block;
  font: 600 14px/1 'Cormorant Garamond', serif;
  color: rgba(200,122,42,.5);
}
.oz-dash__stat-mini-lbl {
  display: block; margin-top: 2px;
  font: 500 7px/1.2 'Space Grotesk', sans-serif;
  text-transform: uppercase; letter-spacing: 1px;
  color: rgba(200,122,42,.2);
}

/* Main terminal area */
.oz-dash__main { display: flex; flex-direction: column; overflow: hidden; min-width: 0; }
.oz-dash__main-header {
  display: flex; gap: 0;
  border-bottom: 1px solid var(--oz-glow);
  padding: 0;
}
.oz-dash__tab {
  padding: 10px 16px;
  font: 600 9px/1 'Space Grotesk', sans-serif;
  text-transform: uppercase; letter-spacing: 1.5px;
  color: rgba(200,122,42,.2);
  border-bottom: 2px solid transparent;
  transition: color .2s;
}
.oz-dash__tab--active {
  color: rgba(200,122,42,.6);
  border-bottom-color: var(--oz);
}

.oz-hero__terminal {
  padding: clamp(16px, 2vw, 24px);
  flex: 1;
  font: 400 clamp(9.5px, 0.8vw, 12px)/1.85 'Space Grotesk', 'Courier New', monospace;
  color: rgba(200,122,42,.45);
  background-image: repeating-linear-gradient(
    0deg, transparent, transparent 2px, rgba(0,0,0,.04) 2px, rgba(0,0,0,.04) 4px
  );
}

/* Evidence summary bar at bottom of main */
.oz-dash__summary {
  display: flex; gap: 0;
  border-top: 1px solid var(--oz-glow);
  margin-top: auto;
}
.oz-dash__summary-item {
  flex: 1; padding: 10px 14px;
  border-right: 1px solid rgba(200,122,42,.04);
  text-align: center;
}
.oz-dash__summary-item:last-child { border-right: none; }
.oz-dash__summary-val {
  display: block;
  font: 600 13px/1 'Space Grotesk', sans-serif;
  color: rgba(200,122,42,.4);
}
.oz-dash__summary-lbl {
  display: block; margin-top: 3px;
  font: 500 7px/1 'Space Grotesk', sans-serif;
  text-transform: uppercase; letter-spacing: 1.5px;
  color: var(--oz-border-strong);
}
.oz-dash__summary-item--accent .oz-dash__summary-val { color: var(--oz); }
.oz-dash__summary-item--accent .oz-dash__summary-lbl { color: rgba(200,122,42,.4); }

/* Hide sidebar on smaller right columns */
@media (max-width: 1200px) {
  .oz-dash { grid-template-columns: 160px 1fr; }
  .oz-dash__sidebar { padding: 12px 10px; }
  .oz-dash__avatar { width: 28px; height: 28px; font-size: 10px; }
}
@media (max-width: 960px) {
  .oz-dash { grid-template-columns: 1fr; }
  .oz-dash__sidebar { display: none; }
}

/* Transcript lines — typewriter */
.oz-wire-line {
  white-space: nowrap; overflow: hidden;
  width: 0; opacity: 0;
}
.oz-hero.is-visible .oz-wire-line {
  animation: ozType 1.6s steps(40, end) forwards, ozLineIn .01s linear forwards;
  animation-delay: calc(var(--i) * .16s + .4s);
}
@keyframes ozType { to { width: 100%; } }
@keyframes ozLineIn { to { opacity: 1; } }

/* Line variants */
.oz-wire-line--header {
  color: rgba(200,122,42,.6);
  font-weight: 600;
  letter-spacing: .5px;
}
.oz-wire-line--meta { color: rgba(200,122,42,.35); }
.oz-wire-line--dim  { color: var(--oz-border); user-select: none; }
.oz-wire-line--accent {
  color: rgba(200,122,42,.85);
  text-shadow: 0 0 12px rgba(200,122,42,.25);
}
.oz-wire-line--key {
  color: var(--oz);
  text-shadow: 0 0 20px rgba(200,122,42,.3);
  font-weight: 600;
}

/* Blinking cursor */
.oz-wire-cursor {
  animation: ozBlink 1s step-end infinite;
  color: var(--oz);
}
@keyframes ozBlink {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0; }
}

/* Suspect name blink (underscores) */
.oz-wire-blink {
  animation: ozBlink 2.5s ease-in-out infinite;
  color: var(--oz);
}

/* Scan-line sweep */
.oz-hero__scanline {
  position: absolute; left: 0; right: 0; z-index: 2;
  height: 60px; top: -60px;
  background: linear-gradient(180deg, transparent, rgba(200,122,42,.02), transparent);
  pointer-events: none;
  animation: ozScan 7s linear 2s infinite;
}
@keyframes ozScan { 0% { top: -60px; } 100% { top: 100%; } }

/* Gradient overlays — no longer needed with grid layout, kept as no-ops */

/* Breadcrumb */
.oz-hero__breadcrumb ol {
  display: flex; flex-wrap: wrap; gap: 5px;
  list-style: none; margin: 0 0 24px; padding: 0;
  font: 500 11.5px/1.4 var(--font-body); color: #556B62;
}
.oz-hero__breadcrumb li:not(:last-child)::after { content: '›'; margin-left: 5px; }
.oz-hero__breadcrumb a { color: inherit; text-decoration: none; transition: color .2s; }
.oz-hero__breadcrumb a:hover { color: var(--oz); }
.oz-hero__breadcrumb [aria-current] span { color: #7A9A8A; }

/* Eyebrow */
.oz-hero__eyebrow {
  margin-bottom: 36px;
  font: 600 9.5px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 4px;
  color: var(--oz-text-dim);
  display: flex; align-items: center; gap: 14px;
}
.oz-hero__eyebrow::before {
  content: ''; width: 32px; height: 1px;
  background: linear-gradient(90deg, var(--oz), transparent);
}

/* H1 — heavy sans + light serif italic */
.oz-hero__heading { margin: 0 0 24px; }
.oz-hero__h1-line1 {
  display: block;
  font: 700 clamp(36px, 3.4vw, 52px)/1 var(--font-body);
  color: #EBE8E2; letter-spacing: -.04em;
}
.oz-hero__h1-line2 {
  display: block; margin-top: 12px;
  font: italic 400 clamp(27px, 2.7vw, 42px)/1.2 var(--font-display);
  color: var(--oz); letter-spacing: -.015em;
}

/* Lead */
.oz-hero__lead {
  font: 400 15px/1.8 var(--font-body);
  color: var(--oz-text); max-width: 540px; margin: 0 0 28px;
}

/* Stats strip */
.oz-hero__stats {
  display: flex; align-items: center; gap: 24px;
  padding: 18px 0; margin-bottom: 28px;
  border-top: 1px solid var(--oz-border); border-bottom: 1px solid var(--oz-border);
}
.oz-hero__stat-num {
  display: block;
  font: 600 28px/1 var(--font-display); color: var(--oz);
}
.oz-hero__stat-lbl {
  display: block; margin-top: 5px;
  font: 500 9px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 2px; color: var(--oz-text-dim);
}
.oz-hero__stat-sep { width: 1px; height: 32px; background: var(--oz-border); flex-shrink: 0; }

/* CTA buttons */
.oz-hero__ctas { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 18px; }
.oz-hero__btn-primary {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--oz); color: var(--oz-bg);
  font: 700 14px/1 var(--font-body);
  border-radius: 10px; padding: 15px 30px;
  text-decoration: none;
  transition: background .25s, transform .25s, box-shadow .25s;
}
.oz-hero__btn-primary:hover {
  background: var(--oz-light); transform: translateY(-2px);
  box-shadow: 0 6px 28px rgba(200,122,42,.35);
}
.oz-hero__btn-primary svg { flex-shrink: 0; }
.oz-hero__btn-ghost {
  display: inline-flex; align-items: center;
  background: transparent; border: 1px solid var(--oz-border-strong); color: var(--oz-text);
  font: 600 14px/1 var(--font-body);
  border-radius: 10px; padding: 15px 24px;
  text-decoration: none; transition: border-color .25s, color .25s;
}
.oz-hero__btn-ghost:hover { border-color: var(--oz); color: var(--oz); }

/* Trust */
.oz-hero__trust { font: 500 10.5px/1 var(--font-body); color: var(--oz-text-pale); }

/* ── Text entrance ── */
.oz-anim { opacity: 0; transform: translateY(24px); }
.oz-hero.is-visible .oz-anim {
  animation: ozUp .75s cubic-bezier(.16, 1, .3, 1) forwards;
}
.oz-hero.is-visible .oz-anim[data-d="0"] { animation-delay: .05s; }
.oz-hero.is-visible .oz-anim[data-d="1"] { animation-delay: .2s; }
.oz-hero.is-visible .oz-anim[data-d="2"] { animation-delay: .4s; }
.oz-hero.is-visible .oz-anim[data-d="3"] { animation-delay: .6s; }
.oz-hero.is-visible .oz-anim[data-d="4"] { animation-delay: .8s; }
.oz-hero.is-visible .oz-anim[data-d="5"] { animation-delay: 1s; }
.oz-hero.is-visible .oz-anim[data-d="6"] { animation-delay: 1.2s; }
.oz-hero.is-visible .oz-anim[data-d="7"] { animation-delay: 1.4s; }
.oz-hero.is-visible .oz-anim[data-d="8"] { animation-delay: 1.6s; }

/* Hero testimonial — dark theme overrides */
.oz-hero__testimonials { margin-bottom: 28px; }
.oz-hero__testimonials .hh-testimonial__slide p {
  color: var(--oz-text);
  font-size: 14px;
}
.oz-hero__testimonials .hh-testimonial__slide cite {
  color: var(--oz-text-dim);
  font-size: 12px;
}
.oz-hero__testimonials .hh-testimonial__dot {
  background: var(--oz-border-strong);
}
.oz-hero__testimonials .hh-testimonial__dot.is-active {
  background: var(--oz);
}
@keyframes ozUp {
  to { opacity: 1; transform: translateY(0); }
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  .oz-wire-line { width: 100% !important; opacity: 1 !important; animation: none !important; }
  .oz-hero__scanline { animation: none !important; display: none; }
  .oz-wire-cursor, .oz-wire-blink { animation: none !important; }
}

/* ── Responsive ── */
@media (max-width: 960px) {
  .oz-hero { height: auto; padding: 0; flex-direction: column; align-items: stretch; justify-content: center; }
  .oz-hero__text {
    width: 100%;
    padding-top: 100px;
    padding-left: clamp(20px, 12px + 3vw, 96px);
    padding-right: clamp(20px, 12px + 3vw, 96px);
    padding-bottom: clamp(32px, 4vw, 48px);
  }
  .oz-hero__wire {
    position: relative;
    top: auto; right: auto;
    width: 100%; height: 320px;
    opacity: .5;
    border-left: none;
    border-top: 1px solid var(--oz-glow);
    z-index: 2;
  }
  .oz-hero__wire .oz-hero__terminal { padding: 16px clamp(20px, 12px + 3vw, 96px); }
  .oz-hero__wire::after {
    content: '';
    position: absolute; bottom: 0; left: 0; right: 0; height: 60px;
    background: linear-gradient(180deg, transparent, var(--oz-bg));
    pointer-events: none;
  }
}
@media (max-width: 600px) {
  .oz-hero__wire { height: 260px; }
  .oz-hero__ctas { flex-direction: column; }
  .oz-hero__btn-primary, .oz-hero__btn-ghost { width: 100%; justify-content: center; }
  .oz-hero__stats { gap: 16px; }
  .oz-hero__stat-num { font-size: 22px; }
}

/* ── S2: QUALIFIER — DARK DOSSIER STYLE ── */
.oz-qualifier {
  background: var(--oz-bg);
  padding: clamp(72px, 7vw, 128px) 0;
}
.oz-qualifier__header { text-align: center; margin-bottom: 48px; }
.oz-qualifier__eyebrow {
  display: block;
  font: 600 10px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 3.5px;
  color: var(--oz);
  margin-bottom: 16px;
}
.oz-qualifier__headline {
  font: 600 clamp(1.75rem, 1.4rem + 1.5vw, 2.5rem)/1.2 var(--font-display);
  color: #EBE8E2;
  margin: 0 0 12px;
}
.oz-qualifier__sub {
  font: 400 15px/1.7 var(--font-body);
  color: var(--oz-text);
  max-width: 540px; margin: 0 auto;
}

/* Tabs — numbered file selectors */
.oz-qualifier__tabs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 0;
}
.oz-qualifier__tab {
  display: flex; align-items: flex-start; gap: 14px;
  padding: 20px; text-align: left;
  background: rgba(200,122,42,.02);
  border: 1px solid rgba(200,122,42,.06);
  color: var(--oz-text);
  cursor: pointer;
  transition: all 0.3s ease;
  border-radius: 14px 14px 0 0;
}
.oz-qualifier__tab:hover { border-color: rgba(200,122,42,.15); color: #D4A060; }
.oz-qualifier__tab.is-active {
  background: var(--oz-bg-card);
  border-color: rgba(200,122,42,.2);
  border-bottom-color: var(--oz-bg-card);
  color: #EBE8E2;
}
.oz-qualifier__tab-badge {
  font: 700 11px/1 var(--font-body);
  color: var(--oz);
  background: rgba(200,122,42,.08);
  border: 1px solid rgba(200,122,42,.12);
  border-radius: 6px;
  padding: 6px 8px;
  flex-shrink: 0;
}
.oz-qualifier__tab.is-active .oz-qualifier__tab-badge {
  background: var(--oz);
  color: var(--oz-bg);
  border-color: var(--oz);
}
.oz-qualifier__tab-content { display: flex; flex-direction: column; gap: 4px; }
.oz-qualifier__tab-title {
  font: 600 14px/1.3 var(--font-body);
}
.oz-qualifier__tab-desc {
  font: 400 11px/1.3 var(--font-body);
  opacity: .5;
}
.oz-qualifier__tab.is-active .oz-qualifier__tab-desc { opacity: .7; }

/* Panels — dossier cards */
.oz-qualifier__panels {}
.oz-qualifier__panel {
  background: var(--oz-bg-card);
  border: 1px solid rgba(200,122,42,.12);
  border-top: none;
  border-radius: 0 0 14px 14px;
  padding: clamp(28px, 3vw, 40px);
}
.oz-qualifier__panel[hidden] { display: none; }

/* Panel header — tag + reference */
.oz-qualifier__panel-header {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(200,122,42,.06);
}
.oz-qualifier__panel-tag {
  font: 700 9px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 2px;
  color: var(--oz);
  background: rgba(200,122,42,.08);
  padding: 6px 12px;
  border-radius: 4px;
}
.oz-qualifier__panel-ref {
  font: 500 9px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 1.5px;
  color: var(--oz-text-dim);
}

.oz-qualifier__panel-lead {
  font: 400 15px/1.75 var(--font-body);
  color: #B0A898;
  margin: 0 0 24px;
}

/* Two-column grid: checklist + aside info */
.oz-qualifier__panel-grid {
  display: grid;
  grid-template-columns: 1fr 260px;
  gap: clamp(24px, 3vw, 40px);
  margin-bottom: 24px;
}
.oz-qualifier__panel-subtitle {
  font: 600 13px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 1px;
  color: #D4A060;
  margin: 0 0 14px;
}
.oz-qualifier__checklist {
  list-style: none; padding: 0; margin: 0;
}
.oz-qualifier__checklist li {
  display: flex; align-items: flex-start; gap: 12px;
  font: 400 14px/1.7 var(--font-body);
  color: #9A9088;
  padding: 5px 0;
}
.oz-check {
  display: flex; align-items: center; justify-content: center;
  width: 22px; height: 22px; min-width: 22px;
  background: rgba(200,122,42,.08);
  border: 1px solid rgba(200,122,42,.12);
  border-radius: 6px;
  margin-top: 3px;
}
.oz-check svg { color: var(--oz); }

/* Aside column — case info */
.oz-qualifier__panel-col--aside {
  background: rgba(200,122,42,.03);
  border: 1px solid rgba(200,122,42,.06);
  border-radius: 10px;
  padding: 20px;
}
.oz-qualifier__aside-label {
  font: 700 8px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 2px;
  color: var(--oz-text-dim);
  margin-bottom: 8px;
}
.oz-qualifier__aside-val {
  font: 600 24px/1 var(--font-display);
  color: var(--oz);
  margin-bottom: 4px;
}
.oz-qualifier__aside-note {
  font: 400 12px/1.5 var(--font-body);
  color: var(--oz-text);
  margin-bottom: 4px;
}
.oz-qualifier__aside-sep {
  height: 1px;
  background: rgba(200,122,42,.06);
  margin: 14px 0;
}

/* CTA button */
.oz-qualifier__cta {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--oz);
  color: var(--oz-bg);
  font: 700 14px/1 var(--font-body);
  border-radius: 10px;
  padding: 16px 32px;
  text-decoration: none;
  transition: background .25s, transform .25s, box-shadow .25s;
}
.oz-qualifier__cta:hover {
  background: var(--oz-light);
  transform: translateY(-2px);
  box-shadow: 0 6px 28px rgba(200,122,42,.3);
}
.oz-qualifier__cta svg { flex-shrink: 0; }
.oz-qualifier__cta--urgent {
  animation: ozCtaPulse 3s ease-in-out infinite;
}
@keyframes ozCtaPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(200,122,42,0); }
  50% { box-shadow: 0 0 0 8px rgba(200,122,42,.12); }
}

/* Responsive */
@media (max-width: 900px) {
  .oz-qualifier__panel-grid { grid-template-columns: 1fr; }
}
@media (max-width: 700px) {
  .oz-qualifier__tabs { grid-template-columns: 1fr; gap: 8px; }
  .oz-qualifier__tab { border-radius: 10px; }
  .oz-qualifier__tab.is-active { border-bottom-color: rgba(200,122,42,.2); }
  .oz-qualifier__panel { border-radius: 14px; border-top: 1px solid rgba(200,122,42,.12); margin-top: 12px; }
}

/* ── S3: WEIGHT METRICS ── */
.oz-weight {
  background: var(--dark-bg-alt);
  padding: clamp(64px, 6vw, 100px) 0;
}
.oz-weight__grid {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr;
  align-items: start;
  max-width: 960px;
  margin: 0 auto;
  gap: 0;
}
.oz-weight__sep {
  width: 1px;
  align-self: stretch;
  background: var(--dark-border);
  margin: 0 24px;
}
.oz-weight__metric { text-align: center; padding: 8px 0; }
.oz-weight__number {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(3rem, 2.5rem + 3vw, 5rem);
  font-weight: 700;
  color: var(--accent-light);
  line-height: 1;
  margin-bottom: 8px;
}
.oz-weight__unit {
  display: block;
  font-family: var(--font-body);
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--dark-text-muted);
  margin-bottom: 12px;
}
.oz-weight__desc {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--dark-text-secondary);
  max-width: 240px;
  margin: 0 auto;
  line-height: 1.6;
}
.oz-weight__motto {
  text-align: center;
  margin: 48px 0 0;
  padding-top: 32px;
  border-top: 1px solid var(--dark-border);
  font-family: var(--font-display);
  font-size: 18px;
  color: var(--dark-text-secondary);
}
@media (max-width: 700px) {
  .oz-weight__grid { grid-template-columns: 1fr; gap: 40px; }
  .oz-weight__sep { display: none; }
}

/* ── S4: DIFFERENTIATORS — BENTO GRID ── */
.oz-diff {
  background: var(--oz-bg);
  padding: clamp(72px, 7vw, 128px) 0;
}
.oz-diff__header { text-align: center; margin-bottom: 48px; }
.oz-diff__eyebrow {
  display: block;
  font: 600 10px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 3.5px;
  color: var(--oz);
  margin-bottom: 16px;
}
.oz-diff__headline {
  font: 600 clamp(1.75rem, 1.4rem + 1.5vw, 2.5rem)/1.2 var(--font-display);
  color: #EBE8E2;
}

/* Bento layout: 3 columns, 3 rows */
.oz-diff__bento {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-rows: auto auto auto;
  gap: 16px;
}
.oz-diff__card--a { grid-column: 1; grid-row: 1 / 3; }       /* tall left */
.oz-diff__card--b { grid-column: 2 / 4; grid-row: 1; }       /* wide top-right */
.oz-diff__card--c { grid-column: 2; grid-row: 2; }            /* small center */
.oz-diff__card--d { grid-column: 3; grid-row: 2; }            /* small right */
.oz-diff__card--e { grid-column: 1 / 4; grid-row: 3; }       /* full-width bottom */

/* Card base */
.oz-diff__card {
  background: #110E0A;
  border: 1px solid rgba(200,122,42,.1);
  border-radius: 16px;
  padding: clamp(24px, 2.5vw, 32px);
  display: flex; flex-direction: column;
  transition: border-color .3s;
}
.oz-diff__card:hover { border-color: rgba(200,122,42,.25); }

.oz-diff__card-num {
  font: 700 11px/1 var(--font-body);
  color: var(--oz);
  background: rgba(200,122,42,.08);
  border: 1px solid rgba(200,122,42,.12);
  border-radius: 6px;
  padding: 5px 8px;
  width: fit-content;
  margin-bottom: 16px;
}
.oz-diff__card-title {
  font: 600 clamp(1.15rem, 1rem + 0.5vw, 1.4rem)/1.25 var(--font-display);
  color: #EBE8E2;
  margin: 0 0 12px;
}
.oz-diff__card-text {
  font: 400 13.5px/1.7 var(--font-body);
  color: #9A9088;
  margin: 0;
  flex: 1;
}

/* Stat block */
.oz-diff__card-stat {
  padding: 16px;
  background: rgba(200,122,42,.04);
  border: 1px solid rgba(200,122,42,.06);
  border-radius: 10px;
  text-align: center;
  margin-bottom: 16px;
}
.oz-diff__card-stat-val {
  display: block;
  font: 700 clamp(32px, 3vw, 44px)/1 var(--font-display);
  color: var(--oz);
}
.oz-diff__card-stat-lbl {
  display: block; margin-top: 6px;
  font: 500 9px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 2px;
  color: var(--oz-text-dim);
}

/* Breakdown rows (card A) */
.oz-diff__card-breakdown {
  display: flex; flex-direction: column; gap: 0;
  margin-top: 16px;
  border-top: 1px solid rgba(200,122,42,.06);
  padding-top: 14px;
}
.oz-diff__breakdown-row {
  display: flex; align-items: baseline; gap: 10px;
  padding: 7px 0;
  border-bottom: 1px solid rgba(200,122,42,.03);
}
.oz-diff__breakdown-row:last-child { border-bottom: none; }
.oz-diff__breakdown-val {
  font: 600 18px/1 var(--font-display);
  color: var(--oz);
  min-width: 52px;
}
.oz-diff__breakdown-lbl {
  font: 400 12px/1.3 var(--font-body);
  color: var(--oz-text);
}
.oz-diff__card-note {
  font: italic 400 13px/1.6 var(--font-display);
  color: var(--oz-text);
  margin: 14px 0 0;
  padding-top: 12px;
  border-top: 1px solid rgba(200,122,42,.04);
}

/* Timeline rows (card B) */
.oz-diff__card-timeline {
  display: flex; flex-direction: column; gap: 0;
  margin-top: 12px;
}
.oz-diff__tl-row {
  display: grid;
  grid-template-columns: 48px 8px 1fr auto;
  align-items: center; gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(200,122,42,.04);
}
.oz-diff__tl-row:last-child { border-bottom: none; }
.oz-diff__tl-time {
  font: 600 18px/1 var(--font-display);
  color: var(--oz);
}
.oz-diff__tl-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: rgba(200,122,42,.3);
}
.oz-diff__tl-event {
  font: 400 13px/1.3 var(--font-body);
  color: #9A9088;
}
.oz-diff__tl-action {
  font: 700 8px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 1.5px;
  color: var(--oz);
  background: rgba(200,122,42,.08);
  padding: 5px 10px;
  border-radius: 4px;
  white-space: nowrap;
}

/* Pill tags (card C) */
.oz-diff__card-tag-row {
  display: flex; flex-wrap: wrap; gap: 6px;
  margin-top: 14px;
}
.oz-diff__pill {
  font: 600 8px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 1.5px;
  color: var(--oz);
  background: rgba(200,122,42,.06);
  border: 1px solid rgba(200,122,42,.1);
  padding: 5px 10px;
  border-radius: 4px;
}

/* Card E: horizontal inner layout */
.oz-diff__card-inner-row {
  display: flex; align-items: center; gap: clamp(24px, 3vw, 48px);
}
.oz-diff__card-inner-row > div:first-child { flex: 1; }
.oz-diff__card-stat--compact {
  min-width: 140px; flex-shrink: 0;
}

/* Responsive */
@media (max-width: 960px) {
  .oz-diff__bento {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto;
  }
  .oz-diff__card--a { grid-column: 1 / 3; grid-row: auto; }
  .oz-diff__card--b { grid-column: 1 / 3; grid-row: auto; }
  .oz-diff__card--c { grid-column: 1; grid-row: auto; }
  .oz-diff__card--d { grid-column: 2; grid-row: auto; }
  .oz-diff__card--e { grid-column: 1 / 3; grid-row: auto; }
}
@media (max-width: 600px) {
  .oz-diff__bento { grid-template-columns: 1fr; }
  .oz-diff__card--a, .oz-diff__card--b, .oz-diff__card--c,
  .oz-diff__card--d, .oz-diff__card--e { grid-column: 1; }
  .oz-diff__card-inner-row { flex-direction: column; gap: 16px; }
  .oz-diff__card-stat--compact { min-width: auto; width: 100%; }
  .oz-diff__tl-row { grid-template-columns: 42px 6px 1fr; }
  .oz-diff__tl-action { grid-column: 3; margin-top: 4px; width: fit-content; }
}

/* ── INLINE CTA — DARK EMERGENCY CARD ── */
.oz-inline-cta {
  padding: clamp(48px, 5vw, 72px) 0;
  background: var(--oz-bg);
}
.oz-inline-cta__card {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 4vw, 56px);
  align-items: center;
  background: #110E0A;
  border: 1px solid rgba(200,122,42,.1);
  border-radius: 20px;
  padding: clamp(32px, 3.5vw, 48px);
}

/* Left: text */
.oz-inline-cta__badge {
  display: inline-block;
  font: 700 9px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 2.5px;
  color: var(--oz-bg);
  background: var(--oz);
  padding: 5px 12px;
  border-radius: 4px;
  margin-bottom: 16px;
}
.oz-inline-cta__headline {
  font: 600 clamp(1.3rem, 1.1rem + 0.8vw, 1.75rem)/1.25 var(--font-display);
  color: #EBE8E2;
  margin: 0 0 12px;
}
.oz-inline-cta__sub {
  font: 400 14px/1.7 var(--font-body);
  color: #9A9088;
  margin: 0;
}

/* Right: actions */
.oz-inline-cta__right {
  display: flex; flex-direction: column; gap: 14px;
}
.oz-inline-cta__phone-btn {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  background: var(--oz);
  color: var(--oz-bg);
  font: 700 16px/1 var(--font-body);
  border-radius: 12px;
  padding: 18px 24px;
  text-decoration: none;
  transition: background .25s, transform .25s, box-shadow .25s;
}
.oz-inline-cta__phone-btn:hover {
  background: var(--oz-light);
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(200,122,42,.3);
}
.oz-inline-cta__phone-btn svg { flex-shrink: 0; }
.oz-inline-cta__avail {
  font: 500 11px/1 var(--font-body);
  color: var(--oz-text);
  text-align: center;
}
.oz-inline-cta__channels {
  border-top: 1px solid rgba(200,122,42,.06);
  padding-top: 14px;
}
.oz-inline-cta__channels-label {
  display: block;
  font: 500 10px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 1.5px;
  color: var(--oz-text-dim);
  margin-bottom: 10px;
  text-align: center;
}
.oz-inline-cta__channels-row {
  display: flex; gap: 8px;
}
.oz-inline-cta__channel {
  flex: 1;
  display: flex; align-items: center; justify-content: center; gap: 6px;
  padding: 10px 12px;
  background: rgba(200,122,42,.04);
  border: 1px solid rgba(200,122,42,.08);
  border-radius: 8px;
  font: 600 11px/1 var(--font-body);
  color: var(--oz-text);
  text-decoration: none;
  transition: border-color .2s, color .2s;
}
.oz-inline-cta__channel:hover {
  border-color: rgba(200,122,42,.25);
  color: var(--oz);
}
.oz-inline-cta__channel svg { flex-shrink: 0; }
.oz-inline-cta__enc {
  font: 400 10px/1.4 var(--font-body);
  color: var(--oz-text-dim);
  text-align: center;
  margin: 10px 0 0;
}

@media (max-width: 768px) {
  .oz-inline-cta__card { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .oz-inline-cta__channels-row { flex-direction: column; }
}

/* ── S5: PENALTIES — TABLE + ART.65 ── */
.oz-penalties {
  background: #110E0A;
  padding: clamp(72px, 7vw, 128px) 0;
}
.oz-penalties__header { text-align: center; margin-bottom: 56px; }
.oz-penalties__eyebrow {
  display: block;
  font: 600 10px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 3.5px;
  color: var(--oz);
  margin-bottom: 16px;
}
.oz-penalties__headline {
  font: 600 clamp(1.6rem, 1.3rem + 1.3vw, 2.25rem)/1.25 var(--font-display);
  color: #EBE8E2;
  max-width: 700px; margin: 0 auto 16px;
}
.oz-penalties__lead {
  font: 400 15px/1.7 var(--font-body);
  color: var(--oz-text);
  max-width: 620px; margin: 0 auto;
}
.oz-penalties__lead em { color: #D4A060; font-style: normal; }

/* Two-column layout: table left, art.65 right */
.oz-pen-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(20px, 3vw, 40px);
  align-items: start;
}

/* Interactive penalty table (left) */
.oz-pen-table {
  margin-bottom: 0;
}
.oz-pen-table__label {
  font: 600 15px/1.3 var(--font-display);
  color: #EBE8E2;
  margin-bottom: 16px;
}
.oz-pen-table__label span {
  font: 400 12px/1.4 var(--font-body);
  color: var(--oz-text);
}
.oz-pen-table__head {
  display: grid;
  grid-template-columns: 44px 1fr 56px 20px 56px 48px;
  gap: 6px; align-items: center;
  padding: 0 16px 10px;
  border-bottom: 1px solid rgba(200,122,42,.08);
}
.oz-pen-table__col-label {
  font: 600 7px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 1.5px;
  color: var(--oz-text-dim);
}

.oz-pen-table__row {
  display: grid;
  grid-template-columns: 44px 1fr 56px 20px 56px 48px;
  gap: 6px; align-items: center;
  padding: 14px 16px;
  border-bottom: 1px solid rgba(200,122,42,.04);
  cursor: pointer;
  transition: background .2s;
}
.oz-pen-table__row:hover { background: rgba(200,122,42,.02); }
.oz-pen-table__row.is-open { background: rgba(200,122,42,.03); }
.oz-pen-table__row--severe { border-left: 3px solid var(--oz); }

.oz-pen-table__cell { font: 400 14px/1.3 var(--font-body); color: #B0A898; }
.oz-pen-table__cell--badge {
  font: 700 12px/1 var(--font-body);
  color: var(--oz);
  background: rgba(200,122,42,.08);
  border: 1px solid rgba(200,122,42,.12);
  border-radius: 4px;
  padding: 6px 0; text-align: center;
}
.oz-pen-table__cell--name { font-weight: 500; }
.oz-pen-table__cell--old {
  font: 500 15px/1 var(--font-display);
  color: var(--oz-text-dim);
  text-decoration: line-through;
  text-decoration-color: rgba(200,122,42,.2);
  text-align: center;
}
.oz-pen-table__cell--arrow { color: var(--oz-text-dim); text-align: center; font-size: 13px; }
.oz-pen-table__cell--new {
  font: 700 20px/1 var(--font-display);
  color: var(--oz);
  text-align: center;
}
.oz-pen-table__cell--pct {
  font: 700 11px/1 var(--font-body);
  color: var(--oz-bg);
  background: var(--oz);
  padding: 5px 0;
  border-radius: 4px;
  text-align: center;
}

/* Expandable detail */
.oz-pen-table__expand {
  grid-column: 1 / -1;
  max-height: 0; overflow: hidden;
  transition: max-height .4s ease;
}
.oz-pen-table__row.is-open .oz-pen-table__expand {
  max-height: 200px;
}
.oz-pen-table__expand p {
  font: 400 13px/1.65 var(--font-body);
  color: #9A9088;
  margin: 0;
  border-top: 1px solid rgba(200,122,42,.06);
  padding: 10px 0 4px;
}

.oz-pen-table__hint {
  font: 400 11px/1 var(--font-body);
  color: var(--oz-text-dim);
  text-align: center;
  margin: 14px 0 0;
}

/* Art. 65 — interactive accordion (right column) */
.oz-pen-65 {}
.oz-pen-65__header { margin-bottom: 28px; }
.oz-pen-65__tag {
  display: inline-block;
  font: 700 9px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 2px;
  color: var(--oz-bg);
  background: var(--oz);
  padding: 5px 10px;
  border-radius: 4px;
  margin-bottom: 14px;
}
.oz-pen-65__title {
  font: 600 clamp(1.2rem, 1rem + 0.5vw, 1.5rem)/1.25 var(--font-display);
  color: #EBE8E2;
  margin: 0 0 10px;
}
.oz-pen-65__sub {
  font: 400 14px/1.7 var(--font-body);
  color: var(--oz-text);
  max-width: 640px; margin: 0;
}
.oz-pen-65__sub strong { color: #D4A060; font-weight: 600; }

/* Accordion items */
.oz-pen-65__accordion { display: flex; flex-direction: column; gap: 0; }

.oz-pen-65__item {
  border-bottom: 1px solid rgba(200,122,42,.06);
}
.oz-pen-65__item--accent {
  border-bottom: none;
}

/* Trigger button */
.oz-pen-65__trigger {
  width: 100%;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 20px 0;
  background: none; border: none; cursor: pointer;
  text-align: left;
  transition: opacity .2s;
}
.oz-pen-65__item--accent .oz-pen-65__trigger { padding: 20px 0; }
.oz-pen-65__trigger:hover { opacity: .85; }

.oz-pen-65__trigger-left {
  display: flex; align-items: center; gap: 16px;
  flex: 1; min-width: 0;
}
.oz-pen-65__trigger-title {
  font: 600 16px/1.3 var(--font-display);
  color: #EBE8E2;
}
.oz-pen-65__item--accent .oz-pen-65__trigger-title { color: var(--oz); }

.oz-pen-65__trigger-icon {
  flex-shrink: 0;
  width: 28px; height: 28px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  border: 1px solid rgba(200,122,42,.12);
  color: var(--oz-text-dim);
  transition: transform .3s, border-color .3s;
}
.oz-pen-65__trigger-icon svg line:first-child {
  transition: transform .3s, opacity .3s;
  transform-origin: center;
}
.oz-pen-65__item.is-open .oz-pen-65__trigger-icon {
  border-color: var(--oz);
  color: var(--oz);
}
.oz-pen-65__item.is-open .oz-pen-65__trigger-icon svg line:first-child {
  transform: rotate(90deg); opacity: 0;
}

/* Compare badge inline with trigger */
.oz-pen-65__compare {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(200,122,42,.06);
  border: 1px solid rgba(200,122,42,.1);
  border-radius: 6px;
  padding: 5px 10px;
  flex-shrink: 0;
}
.oz-pen-65__val-old {
  font: 600 14px/1 var(--font-display);
  color: var(--oz-text-dim);
  text-decoration: line-through;
  text-decoration-color: rgba(200,122,42,.3);
}
.oz-pen-65__arr { color: var(--oz-text-dim); font-size: 11px; }
.oz-pen-65__val-new {
  font: 700 16px/1 var(--font-display);
  color: var(--oz);
}

/* Expandable body */
.oz-pen-65__body {
  max-height: 0; overflow: hidden;
  transition: max-height .5s cubic-bezier(.16,1,.3,1);
}
.oz-pen-65__item.is-open .oz-pen-65__body {
  max-height: 600px;
}
.oz-pen-65__body-inner {
  padding: 0 0 24px;
}
.oz-pen-65__item--accent .oz-pen-65__body-inner { padding: 0 0 24px; }

.oz-pen-65__body-inner p {
  font: 400 14.5px/1.75 var(--font-body);
  color: #B0A898;
  margin: 0 0 12px;
}
.oz-pen-65__body-inner p:last-child { margin-bottom: 0; }
.oz-pen-65__body-inner strong { color: #D4A060; font-weight: 600; }
.oz-pen-65__body-inner ul {
  list-style: none; padding: 0; margin: 0 0 12px;
}
.oz-pen-65__body-inner li {
  display: flex; align-items: flex-start; gap: 10px;
  font: 400 14px/1.65 var(--font-body);
  color: #9A9088;
  padding: 5px 0;
}
.oz-pen-65__body-inner li::before {
  content: '→';
  color: var(--oz);
  flex-shrink: 0;
  margin-top: 1px;
}

/* Example comparison block */
.oz-pen-65__example {
  display: flex; align-items: center; gap: 16px;
  background: rgba(200,122,42,.03);
  border: 1px solid rgba(200,122,42,.06);
  border-radius: 10px;
  padding: 16px 20px;
  margin-bottom: 16px;
}
.oz-pen-65__example-col { flex: 1; text-align: center; }
.oz-pen-65__example-label {
  display: block;
  font: 600 9px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 1.5px;
  color: var(--oz-text-dim);
  margin-bottom: 8px;
}
.oz-pen-65__example-val {
  display: block;
  font: 700 28px/1 var(--font-display);
  color: var(--oz-text-dim);
}
.oz-pen-65__example-col--accent .oz-pen-65__example-val { color: var(--oz); }
.oz-pen-65__example-col--accent .oz-pen-65__example-label { color: var(--oz-text); }
.oz-pen-65__example-note {
  display: block; margin-top: 4px;
  font: 400 10px/1.3 var(--font-body);
  color: var(--oz-text-dim);
}
.oz-pen-65__example-arrow {
  font: 700 12px/1 var(--font-body);
  color: var(--oz-text-dim);
  flex-shrink: 0;
}

/* Responsive */
@media (max-width: 860px) {
  .oz-pen-table__head { display: none; }
  .oz-pen-table__row {
    grid-template-columns: 48px 1fr;
    grid-template-rows: auto auto;
    gap: 4px 12px;
  }
  .oz-pen-table__cell--badge { grid-row: 1 / 3; align-self: center; }
  .oz-pen-table__cell--name { grid-column: 2; }
  .oz-pen-table__cell--old,
  .oz-pen-table__cell--arrow { display: none; }
  .oz-pen-table__cell--new { grid-column: 2; text-align: left; font-size: 18px; }
  .oz-pen-table__cell--new::before { content: 'do '; font-weight: 400; font-size: 13px; color: var(--oz-text); }
  .oz-pen-table__cell--pct { position: absolute; right: 20px; top: 50%; transform: translateY(-50%); }
  .oz-pen-table__row { position: relative; }

  .oz-pen-layout { grid-template-columns: 1fr; }
  .oz-pen-65__example { flex-direction: column; gap: 8px; }
  .oz-pen-65__example-arrow { display: none; }
}
@media (max-width: 600px) {
  .oz-pen-table__cell--pct { display: none; }
}

/* ── S6: SCOPE — SPLIT LAYOUT + ACCORDION ── */
.oz-scope {
  background: var(--oz-bg);
  padding: clamp(72px, 7vw, 128px) 0;
}
.oz-scope__layout {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: clamp(32px, 4vw, 64px);
  align-items: start;
}

/* Left intro */
.oz-scope__intro { position: sticky; top: 96px; }
.oz-scope__eyebrow {
  display: block;
  font: 600 10px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 3.5px;
  color: var(--oz);
  margin-bottom: 16px;
}
.oz-scope__headline {
  font: 600 clamp(1.5rem, 1.2rem + 1.2vw, 2.1rem)/1.25 var(--font-display);
  color: #EBE8E2;
  margin: 0 0 16px;
}
.oz-scope__lead {
  font: 400 14.5px/1.75 var(--font-body);
  color: var(--oz-text);
  margin: 0 0 28px;
}
.oz-scope__intro-stat {
  display: flex; align-items: center; gap: 14px;
  padding: 20px 0;
  border-top: 1px solid rgba(200,122,42,.08);
  border-bottom: 1px solid rgba(200,122,42,.08);
  margin-bottom: 24px;
}
.oz-scope__intro-stat-val {
  font: 700 36px/1 var(--font-display);
  color: var(--oz);
}
.oz-scope__intro-stat-lbl {
  font: 400 12px/1.4 var(--font-body);
  color: var(--oz-text);
}
.oz-scope__intro-cta {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--oz); color: var(--oz-bg);
  font: 700 14px/1 var(--font-body);
  border-radius: 10px; padding: 15px 28px;
  text-decoration: none;
  transition: background .25s, transform .25s, box-shadow .25s;
}
.oz-scope__intro-cta:hover {
  background: var(--oz-light); transform: translateY(-2px);
  box-shadow: 0 6px 28px rgba(200,122,42,.3);
}
.oz-scope__intro-cta svg { flex-shrink: 0; }

/* Right: scope accordion */
.oz-scope__list { display: flex; flex-direction: column; gap: 0; }
.oz-scope__item { border-bottom: 1px solid rgba(200,122,42,.06); }
.oz-scope__trigger {
  width: 100%;
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  gap: 12px; align-items: center;
  padding: 18px 0;
  background: none; border: none; cursor: pointer;
  text-align: left;
  transition: opacity .2s;
}
.oz-scope__trigger:hover { opacity: .8; }
.oz-scope__trigger-badge {
  font: 700 9px/1 var(--font-body);
  color: var(--oz);
  background: rgba(200,122,42,.08);
  border: 1px solid rgba(200,122,42,.1);
  border-radius: 4px;
  padding: 5px 8px;
  white-space: nowrap;
  text-transform: uppercase; letter-spacing: 1px;
}
.oz-scope__trigger-title {
  font: 500 15px/1.3 var(--font-body);
  color: #EBE8E2;
}
.oz-scope__trigger-penalty {
  font: 600 13px/1 var(--font-display);
  color: var(--oz);
  white-space: nowrap;
}
.oz-scope__trigger-icon {
  width: 24px; height: 24px;
  display: flex; align-items: center; justify-content: center;
  color: var(--oz-text-dim);
  transition: color .3s;
}
.oz-scope__trigger-icon svg line:first-child {
  transition: transform .3s, opacity .3s;
  transform-origin: center;
}
.oz-scope__item.is-open .oz-scope__trigger-icon { color: var(--oz); }
.oz-scope__item.is-open .oz-scope__trigger-icon svg line:first-child {
  transform: rotate(90deg); opacity: 0;
}

.oz-scope__body {
  max-height: 0; overflow: hidden;
  transition: max-height .45s cubic-bezier(.16,1,.3,1);
}
.oz-scope__item.is-open .oz-scope__body { max-height: 300px; }
.oz-scope__body-inner { padding: 0 0 20px; }
.oz-scope__body-inner p {
  font: 400 14px/1.7 var(--font-body);
  color: #B0A898;
  margin: 0 0 10px;
}
.oz-scope__body-inner p:last-child { margin-bottom: 0; }
.oz-scope__body-link {
  display: inline-block;
  font: 600 13px/1 var(--font-body);
  color: var(--oz);
  text-decoration: none;
  margin-top: 6px;
  transition: opacity .2s;
}
.oz-scope__body-link:hover { opacity: .7; }

@media (max-width: 860px) {
  .oz-scope__layout { grid-template-columns: 1fr; }
  .oz-scope__intro { position: static; margin-bottom: 32px; }
}
@media (max-width: 600px) {
  .oz-scope__trigger { grid-template-columns: auto 1fr auto; }
  .oz-scope__trigger-penalty { display: none; }
}

/* ── S7: EXPERT CONTENT + STICKY SIDEBAR ── */
.oz-content {
  background: #110E0A;
  padding: clamp(72px, 7vw, 128px) 0;
}
.oz-content__header { text-align: center; margin-bottom: 48px; }
.oz-content__eyebrow {
  display: block;
  font: 600 10px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 3.5px;
  color: var(--oz);
  margin-bottom: 16px;
}
.oz-content__headline {
  font: 600 clamp(1.6rem, 1.3rem + 1.3vw, 2.25rem)/1.25 var(--font-display);
  color: #EBE8E2;
}

/* 3-column grid: left sidebar | article | right sidebar */
.oz-content__grid {
  display: grid;
  grid-template-columns: 200px 1fr 260px;
  gap: clamp(24px, 3vw, 40px);
  align-items: start;
}

/* Main article */
.oz-content__main h3 {
  font: 600 clamp(1.2rem, 1rem + 0.5vw, 1.45rem)/1.3 var(--font-display);
  color: #EBE8E2;
  margin: 40px 0 16px;
  scroll-margin-top: 120px;
}
.oz-content__main h3:first-child { margin-top: 0; }
.oz-content__main p {
  font: 400 15px/1.8 var(--font-body);
  color: #B0A898;
  margin: 0 0 16px;
}

/* Pull quote */
.oz-pullquote {
  border-left: 3px solid var(--oz);
  padding: 4px 0 4px 24px;
  margin: 28px 0;
}
.oz-pullquote p {
  font: italic 400 clamp(1.1rem, 1rem + 0.3vw, 1.3rem)/1.6 var(--font-display);
  color: #EBE8E2;
  margin: 0;
}

/* Callout box */
.oz-callout {
  background: rgba(200,122,42,.04);
  border-left: 4px solid var(--oz);
  border-radius: 0 12px 12px 0;
  padding: 20px 24px;
  margin: 28px 0;
}
.oz-callout p {
  margin: 0;
  font: 400 15px/1.7 var(--font-body);
  color: #D4A060;
}

/* ── Left sidebar (sticky) ── */
.oz-content__sidebar-left {
  position: sticky; top: 96px;
  display: flex; flex-direction: column; gap: 16px;
}

/* ── Right sidebar (sticky) ── */
.oz-content__sidebar-right {
  position: sticky; top: 96px;
  display: flex; flex-direction: column; gap: 16px;
}

/* TOC */
.oz-content__toc {
  background: var(--oz-bg);
  border: 1px solid rgba(200,122,42,.06);
  border-radius: 14px;
  padding: 20px;
}
.oz-content__toc-title {
  font: 700 10px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 2px;
  color: var(--oz-text-dim);
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(200,122,42,.06);
}
.oz-content__toc-list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 0;
}
.oz-content__toc-link {
  display: block;
  padding: 10px 12px;
  font: 500 13px/1.3 var(--font-body);
  color: var(--oz-text);
  text-decoration: none;
  border-radius: 6px;
  border-left: 2px solid transparent;
  transition: color .2s, background .2s, border-color .2s;
}
.oz-content__toc-link:hover {
  color: #EBE8E2;
  background: rgba(200,122,42,.04);
}
.oz-content__toc-link.is-active {
  color: var(--oz);
  border-left-color: var(--oz);
  background: rgba(200,122,42,.06);
}

/* Sidebar CTA */
.oz-content__sidebar-cta {
  background: var(--oz-bg);
  border: 1px solid rgba(200,122,42,.1);
  border-radius: 14px;
  padding: 20px;
  text-align: center;
}
.oz-content__sidebar-phone {
  display: block;
  font: 700 22px/1 var(--font-display);
  color: var(--oz);
  text-decoration: none;
  margin-bottom: 6px;
  transition: color .2s;
}
.oz-content__sidebar-phone:hover { color: var(--oz-light); }
.oz-content__sidebar-avail {
  font: 500 10px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 2px;
  color: var(--oz-text-dim);
}

/* Sidebar urgency */
.oz-content__sidebar-urgency {
  display: flex; align-items: flex-start; gap: 10px;
  background: rgba(200,122,42,.03);
  border: 1px solid rgba(200,122,42,.08);
  border-radius: 12px;
  padding: 16px;
}
.oz-content__sidebar-urgency .pulse-dot {
  margin-top: 4px; flex-shrink: 0;
}
.oz-content__sidebar-urgency p {
  font: 400 12.5px/1.55 var(--font-body);
  color: var(--oz-text);
  margin: 0;
}
.oz-content__sidebar-urgency strong { color: #D4A060; font-weight: 600; }

/* Contact form (right sidebar) */
.oz-content__form-card {
  background: var(--oz-bg);
  border: 1px solid rgba(200,122,42,.08);
  border-radius: 14px;
  padding: 20px;
}
.oz-content__form-title {
  font: 600 14px/1.2 var(--font-display);
  color: #EBE8E2;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(200,122,42,.06);
}
.oz-content__form { display: flex; flex-direction: column; gap: 10px; }
.oz-content__form-group { display: flex; flex-direction: column; gap: 4px; }
.oz-content__form-label {
  font: 500 10px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 1.5px;
  color: var(--oz-text-dim);
}
.oz-content__form-input {
  background: rgba(200,122,42,.03);
  border: 1px solid rgba(200,122,42,.08);
  border-radius: 8px;
  padding: 10px 12px;
  font: 400 14px/1.3 var(--font-body);
  color: #EBE8E2;
  outline: none;
  transition: border-color .2s;
}
.oz-content__form-input::placeholder { color: var(--oz-text-dim); }
.oz-content__form-input:focus { border-color: var(--oz); }
.oz-content__form-submit {
  background: var(--oz); color: var(--oz-bg);
  font: 700 13px/1 var(--font-body);
  border: none; border-radius: 8px;
  padding: 12px;
  cursor: pointer;
  transition: background .25s;
}
.oz-content__form-submit:hover { background: var(--oz-light); }
.oz-content__form-privacy {
  font: 400 10px/1.4 var(--font-body);
  color: var(--oz-text-dim);
  margin: 4px 0 0;
}
.oz-content__form-privacy a { color: var(--oz-text); text-decoration: underline; }

/* Related articles (right sidebar) */
.oz-content__related {
  display: flex; flex-direction: column; gap: 0;
}
.oz-content__related-title {
  font: 700 10px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 2px;
  color: var(--oz-text-dim);
  margin-bottom: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(200,122,42,.06);
}
.oz-content__related-item {
  display: flex; flex-direction: column; gap: 4px;
  padding: 12px 0;
  border-bottom: 1px solid rgba(200,122,42,.04);
  text-decoration: none;
  transition: opacity .2s;
}
.oz-content__related-item:last-child { border-bottom: none; }
.oz-content__related-item:hover { opacity: .75; }
.oz-content__related-badge {
  font: 600 8px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 1.5px;
  color: var(--oz);
}
.oz-content__related-name {
  font: 500 13px/1.4 var(--font-body);
  color: #B0A898;
}

/* Responsive */
@media (max-width: 1100px) {
  .oz-content__grid { grid-template-columns: 200px 1fr; }
  .oz-content__sidebar-right {
    position: static;
    grid-column: 1 / -1;
    display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
    padding-top: 32px;
    border-top: 1px solid rgba(200,122,42,.06);
  }
}
@media (max-width: 860px) {
  .oz-content__grid { grid-template-columns: 1fr; }
  .oz-content__sidebar-left {
    position: static;
    flex-direction: row; flex-wrap: wrap; gap: 12px;
    padding-bottom: 24px;
    border-bottom: 1px solid rgba(200,122,42,.06);
    margin-bottom: 8px;
  }
  .oz-content__toc { flex: 1; min-width: 200px; }
  .oz-content__sidebar-cta { flex: 1; min-width: 140px; }
  .oz-content__sidebar-urgency { flex-basis: 100%; }
  .oz-content__sidebar-right { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .oz-content__sidebar-left { flex-direction: column; }
  .oz-content__toc { display: none; }
  .oz-content__sidebar-right { grid-template-columns: 1fr; }
}

/* ── CTA DARK INLINE #2 — SPLIT ── */
.oz-cta-dark {
  background: var(--oz-bg);
  padding: clamp(56px, 5vw, 80px) 0;
}
.oz-cta-dark__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 4vw, 64px);
  align-items: center;
}
.oz-cta-dark__headline {
  font: 600 clamp(1.5rem, 1.2rem + 1.3vw, 2.25rem)/1.2 var(--font-display);
  color: #EBE8E2;
  margin: 0 0 12px;
}
.oz-cta-dark__sub {
  font: 400 15px/1.7 var(--font-body);
  color: var(--oz-text);
  margin: 0 0 16px;
}
.oz-cta-dark__trust-row {
  display: flex; flex-wrap: wrap; gap: 6px; align-items: center;
  font: 500 11px/1 var(--font-body);
  color: var(--oz-text-dim);
}
.oz-cta-dark__trust-sep { opacity: .4; }

.oz-cta-dark__right {
  display: flex; flex-direction: column; align-items: center; gap: 16px;
}
.oz-cta-dark__phone {
  display: block;
  font: 700 clamp(28px, 2.5vw, 40px)/1 var(--font-body);
  letter-spacing: -.02em;
  color: var(--oz);
  text-decoration: none;
  text-align: center;
  transition: color .2s, transform .2s;
}
.oz-cta-dark__phone:hover { color: var(--oz-light); transform: scale(1.03); }

.oz-cta-dark__channels { text-align: center; }
.oz-cta-dark__channels-label {
  display: block;
  font: 500 10px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 1.5px;
  color: var(--oz-text-dim);
  margin-bottom: 10px;
}
.oz-cta-dark__channels-row {
  display: flex; gap: 8px; justify-content: center;
}
.oz-cta-dark__channel {
  display: flex; align-items: center; gap: 6px;
  padding: 9px 14px;
  background: rgba(200,122,42,.04);
  border: 1px solid rgba(200,122,42,.08);
  border-radius: 8px;
  font: 600 11px/1 var(--font-body);
  color: var(--oz-text);
  text-decoration: none;
  transition: border-color .2s, color .2s;
}
.oz-cta-dark__channel:hover { border-color: rgba(200,122,42,.25); color: var(--oz); }
.oz-cta-dark__channel svg { flex-shrink: 0; }

@media (max-width: 768px) {
  .oz-cta-dark__inner { grid-template-columns: 1fr; text-align: center; }
  .oz-cta-dark__trust-row { justify-content: center; }
}

/* ── S8: VERTICAL STEPS ── */
.oz-steps {
  background: #110E0A;
  padding: clamp(72px, 7vw, 128px) 0;
}
.oz-steps__header { text-align: center; margin-bottom: 48px; }
.oz-steps__eyebrow {
  display: block;
  font: 600 10px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 3.5px;
  color: var(--oz);
  margin-bottom: 16px;
}
.oz-steps__headline {
  font: 600 clamp(1.6rem, 1.3rem + 1.3vw, 2.25rem)/1.25 var(--font-display);
  color: #EBE8E2;
}

/* Track with vertical line */
.oz-steps__track {
  position: relative;
  max-width: 720px;
  margin: 0 auto;
  padding-left: 80px;
}
.oz-steps__track::before {
  content: '';
  position: absolute;
  left: 26px; top: 0; bottom: 0;
  width: 2px;
  background: rgba(200,122,42,.08);
}
/* Animated line fill */
.oz-steps__track::after {
  content: '';
  position: absolute;
  left: 26px; top: 0;
  width: 2px; height: 0;
  background: var(--oz);
  transition: height 2s cubic-bezier(.16,1,.3,1);
  z-index: 1;
}
.oz-steps__track.is-animated::after { height: 100%; }

/* Step */
.oz-steps__step {
  position: relative;
  padding: 0 0 48px;
  opacity: 0; transform: translateY(28px);
  transition: opacity .6s cubic-bezier(.16,1,.3,1), transform .6s cubic-bezier(.16,1,.3,1);
}
.oz-steps__step:last-child { padding-bottom: 0; }
.oz-steps__step.is-visible { opacity: 1; transform: translateY(0); }

/* Marker */
.oz-steps__marker {
  position: absolute;
  left: -80px; top: 0;
  width: 52px; height: 44px; min-width: 52px;
  border-radius: 10px;
  background: var(--oz);
  display: flex; align-items: center; justify-content: center;
  z-index: 3;
  transition: box-shadow .5s;
}
.oz-steps__marker span {
  font: 700 16px/1 var(--font-body);
  color: var(--oz-bg);
}
/* Hover: amber halo glow */
.oz-steps__step:hover .oz-steps__marker {
  box-shadow: 0 0 0 6px rgba(200,122,42,.15), 0 0 24px rgba(200,122,42,.25);
}

/* Body */
.oz-steps__body-top {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  margin-bottom: 10px;
}
.oz-steps__body h3 {
  font: 600 clamp(1.15rem, 1rem + .4vw, 1.4rem)/1.25 var(--font-display);
  color: #EBE8E2; margin: 0;
}
.oz-steps__pills { display: flex; gap: 6px; }
.oz-steps__pill {
  font: 600 9px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 1px;
  color: var(--oz);
  background: rgba(200,122,42,.06);
  border: 1px solid rgba(200,122,42,.1);
  border-radius: 4px;
  padding: 4px 8px;
  white-space: nowrap;
}
.oz-steps__body p {
  font: 400 14.5px/1.75 var(--font-body);
  color: #B0A898; margin: 0;
}
.oz-steps__body a { color: var(--oz); text-decoration: none; font-weight: 600; }
.oz-steps__body a:hover { text-decoration: underline; }

@media (max-width: 600px) {
  .oz-steps__track { padding-left: 52px; }
  .oz-steps__track::before, .oz-steps__track::after { left: 17px; }
  .oz-steps__marker { left: -52px; width: 36px; height: 36px; min-width: 36px; border-radius: 8px; }
  .oz-steps__marker span { font-size: 13px; }
  .oz-steps__body-top { flex-direction: column; align-items: flex-start; gap: 8px; }
}
@media (prefers-reduced-motion: reduce) {
  .oz-steps__step { opacity: 1; transform: none; transition: none; }
  .oz-steps__track::after { height: 100%; transition: none; }
}

/* ── S9: CASE STUDIES ── */
.oz-cases {
  background: var(--oz-bg);
  padding: clamp(72px, 7vw, 128px) 0;
}
.oz-cases__header { text-align: center; margin-bottom: 56px; }
.oz-cases__eyebrow {
  display: block;
  font: 600 10px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 3.5px;
  color: var(--oz);
  margin-bottom: 16px;
}
.oz-cases__headline {
  font: 600 clamp(1.6rem, 1.3rem + 1.3vw, 2.25rem)/1.25 var(--font-display);
  color: #EBE8E2;
  margin: 0 0 10px;
}
.oz-cases__sub {
  font: 400 13px/1.5 var(--font-body);
  color: var(--oz-text-dim);
}

/* Individual case */
.oz-case {
  background: #110E0A;
  border: 1px solid rgba(200,122,42,.06);
  border-radius: 16px;
  padding: clamp(28px, 3vw, 40px);
  margin-bottom: 20px;
  transition: border-color .3s;
}
.oz-case:last-of-type { margin-bottom: 0; }
.oz-case:hover { border-color: rgba(200,122,42,.15); }

/* Case header */
.oz-case__head {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  margin-bottom: 12px;
}
.oz-case__tag {
  font: 700 9px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 1.5px;
  color: var(--oz);
  background: rgba(200,122,42,.08);
  border: 1px solid rgba(200,122,42,.1);
  border-radius: 4px;
  padding: 5px 10px;
}
.oz-case__type {
  font: 500 12px/1 var(--font-body);
  color: var(--oz-text);
}
.oz-case__title {
  font: 600 clamp(1.2rem, 1rem + .5vw, 1.5rem)/1.25 var(--font-display);
  color: #EBE8E2;
  margin: 0 0 20px;
}

/* Split: media left (sticky), tabbed content right */
.oz-case__split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(20px, 3vw, 40px);
  align-items: start;
}

/* Media */
.oz-case__media {
  position: sticky; top: 96px;
  border-radius: 14px;
  overflow: hidden;
  aspect-ratio: 4 / 3;
}
.oz-case__media-item { display: none; width: 100%; height: 100%; }
.oz-case__media-item.is-active { display: block; }
.oz-case__placeholder {
  width: 100%; height: 100%;
  background: rgba(200,122,42,.03);
  border: 1px dashed rgba(200,122,42,.12);
  border-radius: 14px;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 8px;
}
.oz-case__placeholder-label {
  font: 600 12px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 2px;
  color: var(--oz-text-dim);
}
.oz-case__placeholder-desc {
  font: 400 13px/1.4 var(--font-body);
  color: var(--oz-text);
  max-width: 200px; text-align: center;
}

/* Tab nav */
.oz-case__tab-nav { display: flex; gap: 4px; margin-bottom: 20px; }
.oz-case__tab {
  padding: 10px 16px;
  background: rgba(200,122,42,.03);
  border: 1px solid rgba(200,122,42,.06);
  border-radius: 8px;
  font: 600 12px/1 var(--font-body);
  color: var(--oz-text);
  cursor: pointer;
  transition: all .2s;
}
.oz-case__tab:hover { border-color: rgba(200,122,42,.15); color: #EBE8E2; }
.oz-case__tab.is-active { background: var(--oz); border-color: var(--oz); color: var(--oz-bg); }

/* Panel */
.oz-case__panel { display: none; }
.oz-case__panel.is-active { display: block; }
.oz-case__panel[hidden] { display: none; }

/* 2-col content */
.oz-case__cols {
  display: grid; grid-template-columns: 1.3fr 1fr;
  gap: 0; margin-bottom: 16px;
}
.oz-case__col {
  padding: 0 clamp(12px, 1.5vw, 20px);
  border-right: 1px solid rgba(200,122,42,.04);
}
.oz-case__col:first-child { padding-left: 0; }
.oz-case__col:last-child { padding-right: 0; border-right: none; }
.oz-case__col-label {
  display: block; font: 700 9px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 2px;
  color: var(--oz-text-dim); margin-bottom: 10px;
}
.oz-case__col p { font: 400 14px/1.7 var(--font-body); color: #B0A898; margin: 0; }
.oz-case__col p strong { color: #EBE8E2; font-weight: 600; }
.oz-case__col--result {
  background: rgba(200,122,42,.04); border-radius: 10px;
  padding: clamp(12px, 1.5vw, 20px) !important; border-right: none;
}
.oz-case__col--result .oz-case__col-label { color: var(--oz); }

/* CTA */
.oz-case__cta {
  display: inline-flex; font: 600 13px/1 var(--font-body);
  color: var(--oz); text-decoration: none; transition: opacity .2s;
}
.oz-case__cta:hover { opacity: .7; }

@media (max-width: 860px) {
  .oz-case__split { grid-template-columns: 1fr; }
  .oz-case__media { position: static; aspect-ratio: 16/9; margin-bottom: 8px; }
}
@media (max-width: 600px) {
  .oz-case__cols { grid-template-columns: 1fr; gap: 14px; }
  .oz-case__col { padding: 0; border-right: none; border-bottom: 1px solid rgba(200,122,42,.04); padding-bottom: 14px; }
  .oz-case__col:last-child { border-bottom: none; padding-bottom: 0; }
  .oz-case__tab-nav { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .oz-case__tab { white-space: nowrap; flex-shrink: 0; }
}

/* ── S10: BEFORE / AFTER — TOGGLE SWITCH ── */
.oz-ba {
  background: var(--oz-bg);
  padding: clamp(72px, 7vw, 128px) 0;
}
.oz-ba__header { text-align: center; margin-bottom: 40px; }
.oz-ba__eyebrow {
  display: block;
  font: 600 10px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 3.5px;
  color: var(--oz);
  margin-bottom: 16px;
}
.oz-ba__headline {
  font: 600 clamp(1.6rem, 1.3rem + 1.3vw, 2.25rem)/1.25 var(--font-display);
  color: #EBE8E2;
}

.oz-ba__widget { max-width: 640px; margin: 0 auto; }

/* Toggle */
.oz-ba__toggle {
  display: flex; position: relative;
  background: rgba(200,122,42,.04);
  border: 1px solid rgba(200,122,42,.08);
  border-radius: 12px; padding: 4px;
  margin-bottom: 28px;
}
.oz-ba__toggle-btn {
  flex: 1; padding: 14px 20px;
  background: none; border: none;
  font: 600 14px/1 var(--font-body);
  color: var(--oz-text);
  cursor: pointer; position: relative; z-index: 2;
  transition: color .3s; border-radius: 9px;
}
.oz-ba__toggle-btn.is-active { color: var(--oz-bg); }
.oz-ba__toggle-slider {
  position: absolute; top: 4px; left: 4px;
  width: calc(50% - 4px); height: calc(100% - 8px);
  background: var(--oz); border-radius: 9px;
  transition: transform .4s cubic-bezier(.16,1,.3,1);
  z-index: 1;
}
.oz-ba__widget.is-after .oz-ba__toggle-slider { transform: translateX(100%); }

/* Cards */
.oz-ba__stack { display: flex; flex-direction: column; gap: 0; }
.oz-ba__card {
  position: relative; overflow: hidden;
  border-bottom: 1px solid rgba(200,122,42,.04);
  padding: 18px 0;
}
.oz-ba__card:last-child { border-bottom: none; }

.oz-ba__card-before, .oz-ba__card-after {
  display: flex; align-items: flex-start; gap: 12px;
  font: 400 15px/1.65 var(--font-body);
  transition: opacity .4s ease, transform .4s cubic-bezier(.16,1,.3,1);
}
.oz-ba__card-before p, .oz-ba__card-after p { margin: 0; }
.oz-ba__card-before { color: #9A9088; opacity: 1; transform: translateX(0); }
.oz-ba__card-after {
  color: #D4C0A0;
  position: absolute; top: 18px; left: 0; right: 0;
  opacity: 0; transform: translateX(40px);
}
.oz-ba__widget.is-after .oz-ba__card-before { opacity: 0; transform: translateX(-40px); }
.oz-ba__widget.is-after .oz-ba__card-after { opacity: 1; transform: translateX(0); position: relative; top: auto; }

/* Icons */
.oz-ba__card-icon {
  flex-shrink: 0; width: 24px; height: 24px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 6px; font: 700 13px/1 var(--font-body); margin-top: 1px;
}
.oz-ba__card-icon--x { background: rgba(200,122,42,.06); color: #5A4A3A; }
.oz-ba__card-icon--ok { background: rgba(200,122,42,.12); color: var(--oz); }

/* CTA — revealed in "after" state */
.oz-ba__cta {
  text-align: center; margin-top: 32px;
  opacity: 0; transform: translateY(12px);
  transition: opacity .5s ease .2s, transform .5s cubic-bezier(.16,1,.3,1) .2s;
  pointer-events: none;
}
.oz-ba__widget.is-after .oz-ba__cta { opacity: 1; transform: translateY(0); pointer-events: auto; }
.oz-ba__cta-btn {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--oz); color: var(--oz-bg);
  font: 700 14px/1 var(--font-body);
  border-radius: 10px; padding: 16px 32px;
  text-decoration: none;
  transition: background .25s, transform .25s, box-shadow .25s;
}
.oz-ba__cta-btn:hover {
  background: var(--oz-light); transform: translateY(-2px);
  box-shadow: 0 6px 28px rgba(200,122,42,.3);
}
.oz-ba__cta-btn svg { flex-shrink: 0; }
.oz-ba__cta-note {
  display: block; margin-top: 10px;
  font: 500 11px/1 var(--font-body);
  color: var(--oz-text-dim);
}

@media (prefers-reduced-motion: reduce) {
  .oz-ba__toggle-slider, .oz-ba__card-before, .oz-ba__card-after, .oz-ba__cta { transition: none; }
}

/* ── S11: REVIEWS (homepage carousel, amber override) ── */
.oz-page .reviews {
  background: #110E0A;
}
.oz-page .reviews__eyebrow { color: var(--oz); }
.oz-page .reviews__headline { color: #EBE8E2; }
.oz-page .reviews__card {
  background: var(--oz-bg);
  border-color: rgba(200,122,42,.08);
}
.oz-page .reviews__star--filled { fill: var(--oz); stroke: var(--oz); }
.oz-page .reviews__quote p { color: #B0A898; }
.oz-page .reviews__author { color: #EBE8E2; }
.oz-page .reviews__case { color: var(--oz); }
.oz-page .reviews__source { color: var(--oz-text-dim); }
.oz-page .reviews__arrow {
  background: rgba(200,122,42,.06);
  border-color: rgba(200,122,42,.1);
  color: var(--oz);
}
.oz-page .reviews__arrow:hover {
  background: rgba(200,122,42,.12);
  border-color: rgba(200,122,42,.2);
}
.oz-page .reviews__dot { background: rgba(200,122,42,.15); }
.oz-page .reviews__dot.is-active { background: var(--oz); }
.oz-page .reviews__link { color: var(--oz); }

/* Remove old oz-strip & oz-reviews (replaced by homepage carousel) */
.oz-strip {
  background: var(--bg-secondary);
  padding: 48px 0;
}
.oz-strip__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  text-align: center;
}
.oz-strip__number {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(2rem, 1.5rem + 2vw, 3rem);
  font-weight: 700;
  color: var(--accent);
  line-height: 1;
  margin-bottom: 4px;
}
.oz-strip__label {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text-tertiary);
}
@media (max-width: 600px) {
  .oz-strip__grid { grid-template-columns: repeat(2, 1fr); }
}

/* Reviews */
.oz-reviews {
  background: var(--bg-primary);
  padding: clamp(72px, 7vw, 128px) 0;
}
.oz-reviews__header { text-align: center; margin-bottom: 48px; }
.oz-reviews__eyebrow {
  display: block;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 3px;
  color: var(--accent);
  margin-bottom: 12px;
}
.oz-reviews__headline {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 1.4rem + 1.5vw, 2.5rem);
  font-weight: 600;
  color: var(--text-primary);
}
.oz-reviews__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.oz-reviews__card {
  background: var(--bg-elevated);
  border: 1px solid var(--bg-tertiary);
  border-radius: 14px;
  padding: 28px;
}
.oz-reviews__stars {
  color: #F5B731;
  font-size: 16px;
  letter-spacing: 2px;
  margin-bottom: 16px;
}
.oz-reviews__card p {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text-secondary);
  line-height: 1.7;
  margin: 0 0 16px;
}
.oz-reviews__card cite {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text-muted);
  font-style: normal;
}
.oz-reviews__link-wrap { text-align: center; margin-top: 32px; }
.oz-reviews__link {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--accent);
  text-decoration: none;
  font-weight: 500;
}
.oz-reviews__link:hover { text-decoration: underline; }

@media (max-width: 768px) {
  .oz-reviews__grid { grid-template-columns: 1fr; gap: 16px; overflow-x: auto; flex-wrap: nowrap; display: flex; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; padding-bottom: 8px; }
  .oz-reviews__card { min-width: 300px; scroll-snap-align: center; flex-shrink: 0; }
}

/* ── S12: FAQ — CENTERED, NO SIDEBAR ── */
.oz-faq {
  background: var(--oz-bg);
  padding: clamp(72px, 7vw, 128px) 0;
}
.oz-faq__layout { max-width: 760px; margin: 0 auto; }
.oz-faq__header { text-align: center; margin-bottom: 32px; }
.oz-faq__eyebrow {
  display: block;
  font: 600 10px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 3.5px;
  color: var(--oz);
  margin-bottom: 14px;
}
.oz-faq__headline {
  font: 600 clamp(1.5rem, 1.2rem + 1vw, 2rem)/1.25 var(--font-display);
  color: #EBE8E2;
}
.oz-faq__filters {
  display: flex; flex-wrap: wrap; gap: 6px;
  justify-content: center;
  margin-bottom: 28px;
}
.oz-faq__filter {
  padding: 8px 16px;
  border: 1px solid rgba(200,122,42,.08);
  border-radius: 8px; background: transparent;
  font: 600 12px/1 var(--font-body);
  color: var(--oz-text); cursor: pointer;
  transition: all .2s;
}
.oz-faq__filter:hover { border-color: rgba(200,122,42,.2); color: #EBE8E2; }
.oz-faq__filter.is-active { background: var(--oz); border-color: var(--oz); color: var(--oz-bg); }

.oz-faq__item { border-bottom: 1px solid rgba(200,122,42,.04); }
.oz-faq__item[hidden] { display: none; }
.oz-faq__question {
  width: 100%;
  display: flex; align-items: center;
  justify-content: space-between; gap: 16px;
  padding: 18px 0; background: none; border: none;
  cursor: pointer; text-align: left;
  font: 600 15px/1.4 var(--font-body);
  color: #EBE8E2; transition: color .2s;
}
.oz-faq__question:hover { color: var(--oz); }
.oz-faq__icon { flex-shrink: 0; width: 22px; height: 22px; }
.oz-faq__icon svg {
  width: 22px; height: 22px;
  stroke: var(--oz-text-dim); stroke-width: 1.5;
  fill: none; stroke-linecap: round; transition: transform .3s;
}
.oz-faq__question[aria-expanded="true"] .oz-faq__icon svg line:first-child {
  transform: rotate(90deg); transform-origin: center; opacity: 0;
}
.oz-faq__answer {
  overflow: hidden; max-height: 0;
  transition: max-height .4s cubic-bezier(.16,1,.3,1);
}
.oz-faq__answer[hidden] { display: block; max-height: 0; visibility: hidden; }
.oz-faq__answer:not([hidden]) { visibility: visible; }
.oz-faq__answer-inner {
  padding: 0 0 18px;
  font: 400 14.5px/1.7 var(--font-body); color: #B0A898;
}
.oz-faq__answer-inner p { margin: 0; }
.oz-faq__answer-inner a { color: var(--oz); }

/* Sidebar hidden — moved to sticky bar */
.oz-faq__sidebar { display: none; }

/* ── STICKY CTA BAR (bottom of page) ── */
.oz-sticky-bar {
  position: fixed; bottom: 0; left: 0; right: 0;
  z-index: 90;
  background: rgba(10,8,6,.95);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  border-top: 1px solid rgba(200,122,42,.1);
  padding: 12px 0;
  transform: translateY(100%);
  transition: transform .4s cubic-bezier(.16,1,.3,1);
}
.oz-sticky-bar.is-visible { transform: translateY(0); }
.oz-sticky-bar__inner {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
}
.oz-sticky-bar__text {
  font: 500 14px/1.3 var(--font-body);
  color: #EBE8E2;
}
.oz-sticky-bar__text span {
  display: block;
  font: 400 11px/1.3 var(--font-body);
  color: var(--oz-text-dim);
  margin-top: 2px;
}
.oz-sticky-bar__phone {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--oz); color: var(--oz-bg);
  font: 700 14px/1 var(--font-body);
  border-radius: 8px; padding: 12px 24px;
  text-decoration: none;
  transition: background .2s;
  flex-shrink: 0;
}
.oz-sticky-bar__phone:hover { background: var(--oz-light); }
.oz-sticky-bar__phone svg { flex-shrink: 0; }

@media (max-width: 600px) {
  .oz-faq__filters { overflow-x: auto; flex-wrap: nowrap; -webkit-overflow-scrolling: touch; justify-content: flex-start; }
  .oz-faq__filter { white-space: nowrap; flex-shrink: 0; }
  .oz-sticky-bar__text span { display: none; }
  .oz-sticky-bar__phone { padding: 12px 18px; font-size: 13px; }
}

/* ── S13: RELATED (reuses global .related, amber override) ── */
.oz-page .related { background: #110E0A; }
.oz-page .related__eyebrow { color: var(--oz); }
.oz-page .related__headline { color: #EBE8E2; }
.oz-page .related__card {
  background: var(--oz-bg);
  border-color: rgba(200,122,42,.06);
}
.oz-page .related__card:hover { border-color: rgba(200,122,42,.2); }
.oz-page .related__card-title { color: #EBE8E2; }
.oz-page .related__card-desc { color: var(--oz-text); }
.oz-page .related__card-badge { color: var(--oz); background: rgba(200,122,42,.08); border-color: rgba(200,122,42,.12); }
.oz-page .related__card-arrow svg { stroke: var(--oz); }

/* ── S14: ARTICLES (reuses global .knowledge, amber override) ── */
.oz-page .knowledge { background: var(--oz-bg); }
.oz-page .knowledge__eyebrow { color: var(--oz); }
.oz-page .knowledge__headline { color: #EBE8E2; }
.oz-page .knowledge-card {
  background: #110E0A;
  border-color: rgba(200,122,42,.06);
}
.oz-page .knowledge-card:hover { border-color: rgba(200,122,42,.2); }
.oz-page .knowledge-card__category { color: var(--oz); background: #110E0A; border-color: rgba(200,122,42,.12); }
.oz-page .knowledge-card__title-link { color: #EBE8E2; }
.oz-page .knowledge-card__title-link:hover { color: var(--oz); }
.oz-page .knowledge-card__excerpt { color: var(--oz-text); }

/* ── S15: FINAL CTA — SPLIT LAYOUT ── */
.oz-fcta {
  background: var(--oz-bg);
  padding: clamp(72px, 7vw, 128px) 0;
}
.oz-fcta__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 4vw, 64px);
  align-items: center;
}
.oz-fcta__headline {
  font: 600 clamp(1.5rem, 1.2rem + 1.3vw, 2.25rem)/1.2 var(--font-display);
  color: #EBE8E2;
  margin: 0 0 12px;
}
.oz-fcta__sub {
  font: 400 15px/1.7 var(--font-body);
  color: var(--oz-text);
  margin: 0 0 16px;
}
.oz-fcta__tomorrow {
  font: italic 400 14px/1.6 var(--font-display);
  color: var(--oz-text);
  margin: 0;
}

.oz-fcta__right { display: flex; flex-direction: column; align-items: center; gap: 16px; }
.oz-fcta__phone {
  display: block;
  font: 700 clamp(28px, 2.5vw, 42px)/1 var(--font-body);
  letter-spacing: -.02em;
  color: var(--oz);
  text-decoration: none; text-align: center;
  transition: color .2s, transform .2s;
}
.oz-fcta__phone:hover { color: var(--oz-light); transform: scale(1.03); }
.oz-fcta__channels { text-align: center; }
.oz-fcta__channels-label {
  display: block;
  font: 500 10px/1 var(--font-body);
  text-transform: uppercase; letter-spacing: 1.5px;
  color: var(--oz-text-dim);
  margin-bottom: 10px;
}
.oz-fcta__channels-row { display: flex; gap: 8px; justify-content: center; }
.oz-fcta__channel {
  display: flex; align-items: center; gap: 6px;
  padding: 9px 14px;
  background: rgba(200,122,42,.04);
  border: 1px solid rgba(200,122,42,.08);
  border-radius: 8px;
  font: 600 11px/1 var(--font-body);
  color: var(--oz-text);
  text-decoration: none;
  transition: border-color .2s, color .2s;
}
.oz-fcta__channel:hover { border-color: rgba(200,122,42,.25); color: var(--oz); }
.oz-fcta__channel svg { flex-shrink: 0; }
.oz-fcta__trust {
  font: 500 11px/1 var(--font-body);
  color: var(--oz-text-dim);
  text-align: center;
}

@media (max-width: 768px) {
  .oz-fcta__inner { grid-template-columns: 1fr; text-align: center; }
  .oz-fcta__channels-row { flex-wrap: wrap; }
}

/* ── Generic reveal for OZ page ── */
.oz-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.oz-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* OZ timeline reveal */
.oz-tl-reveal .oz-timeline__body,
.oz-tl-reveal .oz-timeline__marker {
  /* Handled by JS toggling .is-visible on the step */
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  .oz-anim,
  .oz-reveal,
  .oz-tl-reveal .oz-timeline__body,
  .oz-tl-reveal .oz-timeline__marker {
    opacity: 1 !important;
    transform: none !important;
    animation: none !important;
    transition: none !important;
  }
  .oz-penalties__bar { transition: none !important; }
  .oz-timeline__line-fill { transition: none !important; }
}


/* ================================================================
   DOKUMENTY PAGE — dok- prefix
   ================================================================ */

/* ── Hero ── */
.dok-hero {
  position: relative;
  background: var(--dark-bg);
  color: var(--dark-text);
  padding: clamp(100px, 10vw, 160px) 0 clamp(72px, 7vw, 120px) 0;
  overflow: hidden;
}

.dok-hero__topline {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
  opacity: 0.4;
}

.dok-hero__breadcrumb ol {
  display: flex;
  align-items: center;
  gap: 8px;
  list-style: none;
  padding: 0;
  margin: 0 0 24px;
  font-size: 13px;
}

.dok-hero__breadcrumb a {
  color: var(--dark-text-secondary);
  text-decoration: none;
  transition: color 0.2s;
}

.dok-hero__breadcrumb a:hover {
  color: var(--accent-light);
}

.dok-hero__breadcrumb li + li::before {
  content: '\203A';
  margin-right: 8px;
  color: var(--dark-text-secondary);
  opacity: 0.5;
}

.dok-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent-light);
  margin-bottom: 20px;
}

.dok-hero__eyebrow::before {
  content: '';
  display: inline-block;
  width: 28px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--accent-light));
}

.dok-hero__heading {
  font-family: var(--font-display);
  font-size: clamp(32px, 4vw, 52px);
  font-weight: 600;
  line-height: 1.15;
  color: var(--dark-text);
  margin: 0 0 20px;
  max-width: 780px;
}

.dok-hero__heading em {
  font-style: normal;
  font-family: var(--font-display);
  font-weight: 500;
  font-style: italic;
  color: var(--accent-light);
}

.dok-hero__lead {
  font-family: var(--font-body);
  font-size: clamp(18px, 2vw, 23px);
  font-weight: 400;
  line-height: 1.5;
  color: var(--dark-text-secondary);
  margin: 0 0 32px;
  max-width: 680px;
}

.dok-hero__cta-group {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 28px;
}

.dok-hero__btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.dok-hero__btn svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  stroke-width: 2;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.dok-hero__trust {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  font-size: 13px;
  color: var(--dark-text-secondary);
  opacity: 0.7;
}

.dok-hero__trust-sep {
  color: var(--dark-text-secondary);
  opacity: 0.4;
}

/* Hero entrance animations */
@keyframes dokFadeInUp {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}

.dok-anim {
  opacity: 0;
  animation: dokFadeInUp 0.6s ease both;
}

.dok-anim--1 { animation-delay: 0s; }
.dok-anim--2 { animation-delay: 0.1s; }
.dok-anim--3 { animation-delay: 0.2s; }
.dok-anim--4 { animation-delay: 0.3s; }
.dok-anim--5 { animation-delay: 0.4s; }
.dok-anim--6 { animation-delay: 0.5s; }

/* ── Scroll reveal ── */
.dok-reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}

.dok-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ── Value Strip ── */
.dok-vs {
  background: var(--bg-secondary);
  padding: clamp(40px, 5vw, 64px) 0;
}

.dok-vs__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  text-align: center;
}

.dok-vs__number {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-family: var(--font-display);
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 600;
  color: var(--accent);
  line-height: 1.2;
  margin-bottom: 6px;
}

.dok-vs__number svg {
  width: 22px;
  height: 22px;
  fill: var(--accent);
  stroke: none;
}

.dok-vs__number--text {
  font-size: clamp(22px, 2.5vw, 32px);
}

.dok-vs__label {
  font-size: 13px;
  color: var(--text-tertiary);
  line-height: 1.4;
}

/* ── Tabs (sticky) ── */
.dok-tabs {
  position: sticky;
  top: 0;
  z-index: 50;
  display: flex;
  gap: 0;
  background: var(--bg-elevated);
  border-bottom: 1px solid var(--bg-tertiary);
  padding: 0;
  margin-bottom: 24px;
}

.dok-tabs__tab {
  flex: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 20px;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--text-tertiary);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  transition: all 0.3s ease;
}

.dok-tabs__tab:hover {
  color: var(--text-primary);
}

.dok-tabs__tab.is-active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

.dok-tabs__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 18px;
  padding: 0 6px;
  border-radius: 9px;
  font-size: 10px;
  font-weight: 700;
  background: var(--bg-tertiary);
  color: var(--text-muted);
  transition: all 0.3s ease;
}

.dok-tabs__tab.is-active .dok-tabs__count {
  background: var(--accent);
  color: #FFF;
}

/* ── Filters bar ── */
.dok-filters {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 28px;
  flex-wrap: wrap;
}

.dok-filters__chips {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.dok-chip {
  padding: 6px 14px;
  border-radius: 20px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-tertiary);
  background: none;
  border: 1px solid var(--bg-tertiary);
  cursor: pointer;
  transition: all 0.2s ease;
}

.dok-chip:hover {
  border-color: var(--accent-border-solid);
  color: var(--text-secondary);
}

.dok-chip.is-active {
  background: var(--accent-bg-solid);
  border-color: var(--accent-border-solid);
  color: var(--accent);
}

.dok-filters__search {
  position: relative;
}

.dok-filters__search-icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  stroke: var(--text-muted);
  stroke-width: 2;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
  pointer-events: none;
}

.dok-filters__input {
  width: 280px;
  padding: 10px 16px 10px 40px;
  border: 1px solid var(--bg-tertiary);
  border-radius: 10px;
  background: var(--bg-secondary);
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text-primary);
  transition: all 0.2s ease;
}

.dok-filters__input::placeholder {
  color: var(--text-muted);
}

.dok-filters__input:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: var(--shadow-focus);
}

/* ── Documents Main Section ── */
.dok-main {
  background: var(--bg-primary);
  padding: clamp(48px, 6vw, 80px) 0;
}

/* ── Documents Grid ── */
.dok-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}

/* ── Document Card ── */
.doc-card {
  position: relative;
  background: var(--bg-elevated);
  border-radius: 14px;
  border: 1px solid var(--bg-tertiary);
  padding: 28px;
  overflow: hidden;
  transition: all 0.35s ease;
}

.doc-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: var(--accent-border-solid);
}

.doc-card__stripe {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--accent);
  opacity: 0;
  transition: opacity 0.35s ease;
}

.doc-card:hover .doc-card__stripe {
  opacity: 0.4;
}

.doc-card__header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}

.doc-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  min-width: 48px;
  background: var(--accent-bg-solid);
  border: 1px solid var(--accent-border-solid);
  border-radius: 10px;
}

.doc-card__icon svg {
  width: 22px;
  height: 22px;
  stroke: var(--accent);
  stroke-width: 2;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.doc-card__icon--bundle {
  background: var(--champagne-bg-solid);
  border-color: var(--champagne-border-solid);
}

.doc-card__icon--bundle svg {
  stroke: var(--accent-champagne);
}

.doc-card__eyebrow {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.doc-card__title {
  font-family: var(--font-body);
  font-size: 20px;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.3;
  margin: 0 0 8px;
}

.doc-card__desc {
  font-size: 14px;
  line-height: 1.6;
  color: var(--text-tertiary);
  margin: 0 0 16px;
}

.doc-card__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}

.doc-card__badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 600;
}

.doc-card__badge--free {
  background: var(--accent-bg-solid);
  color: var(--accent);
  border: 1px solid var(--accent-border-solid);
}

.doc-card__badge--pages {
  background: var(--bg-secondary);
  color: var(--text-muted);
}

.doc-card__badge--price {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 700;
  color: var(--text-primary);
  background: none;
  padding: 0;
}

.doc-card__badge--old-price {
  font-size: 14px;
  color: var(--text-muted);
  background: none;
  padding: 0;
  align-self: center;
}

/* Features list (paid cards) */
.doc-card__features {
  list-style: none;
  padding: 0;
  margin: 0 0 20px;
}

.doc-card__features li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 14px;
  line-height: 1.5;
  color: var(--text-secondary);
  padding: 4px 0;
}

.doc-card__features li svg {
  width: 16px;
  height: 16px;
  min-width: 16px;
  stroke: var(--accent);
  stroke-width: 2.5;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
  margin-top: 2px;
}

/* Card button */
.doc-card__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 12px 24px;
  border-radius: 10px;
  font-weight: 600;
  text-decoration: none;
  text-align: center;
  font-size: 15px;
}

.doc-card__btn svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  stroke-width: 2;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* Preview link */
.doc-card__preview-link {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 8px 0;
  margin-top: 8px;
  background: none;
  border: none;
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text-muted);
  cursor: pointer;
  transition: color 0.2s;
}

.doc-card__preview-link:hover {
  color: var(--accent);
}

.doc-card__preview-link svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  stroke-width: 2;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* Micro CTA (free cards) */
.doc-card__micro-cta {
  margin-top: 12px;
  font-size: 13px;
  color: var(--text-muted);
  text-align: center;
}

.doc-card__micro-cta a {
  color: var(--accent);
  text-decoration: none;
  font-weight: 500;
}

.doc-card__micro-cta a:hover {
  text-decoration: underline;
}

/* Separator + conversion CTA (paid cards) */
.doc-card__separator {
  height: 1px;
  background: var(--bg-tertiary);
  margin: 16px 0;
}

.doc-card__conversion-cta {
  font-size: 13px;
  color: var(--text-tertiary);
  line-height: 1.5;
}

.doc-card__conversion-cta a {
  display: inline-block;
  margin-top: 4px;
  color: var(--accent);
  font-weight: 500;
  text-decoration: none;
}

.doc-card__conversion-cta a:hover {
  text-decoration: underline;
}

/* Bundle card */
.doc-card--bundle {
  border: 2px solid var(--accent);
}

.doc-card__bundle-badge {
  display: inline-block;
  background: var(--champagne-bg-solid);
  border: 1px solid var(--champagne-border-solid);
  color: var(--accent-champagne);
  font-size: 12px;
  font-weight: 600;
  padding: 4px 12px;
  border-radius: 6px;
  margin-bottom: 10px;
}

/* Coming soon card */
.doc-card--coming-soon {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  border-style: dashed;
  padding: 40px 28px;
  background: var(--bg-secondary);
}

.doc-card--coming-soon:hover {
  transform: none;
  box-shadow: none;
}

.doc-card--coming-soon > svg {
  width: 32px;
  height: 32px;
  stroke: var(--text-muted);
  stroke-width: 2;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
  opacity: 0.4;
  margin-bottom: 12px;
}

.doc-card__coming-title {
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 500;
  color: var(--text-tertiary);
  margin: 0 0 8px;
}

.doc-card__coming-text {
  font-size: 13px;
  color: var(--text-muted);
  margin: 0;
}

.doc-card__coming-text a {
  color: var(--accent);
  text-decoration: none;
}

.doc-card__coming-text a:hover {
  text-decoration: underline;
}

/* No results */
.dok-no-results {
  text-align: center;
  padding: 48px 20px;
}

.dok-no-results > svg {
  width: 48px;
  height: 48px;
  stroke: var(--text-muted);
  stroke-width: 1.5;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
  opacity: 0.3;
  margin-bottom: 16px;
}

.dok-no-results__text {
  font-size: 15px;
  color: var(--text-tertiary);
  margin: 0 0 20px;
}

.dok-no-results .btn-accent {
  display: inline-flex;
  gap: 10px;
}

.dok-no-results .btn-accent svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  stroke-width: 2;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* ── Process Section ── */
.dok-process {
  background: var(--bg-secondary);
  padding: clamp(56px, 7vw, 96px) 0;
}

.dok-process__header {
  text-align: center;
  margin-bottom: clamp(36px, 4vw, 56px);
}

.dok-process__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
}

.dok-process__eyebrow::before,
.dok-process__eyebrow::after {
  content: '';
  width: 24px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--accent));
}

.dok-process__eyebrow::after {
  background: linear-gradient(90deg, var(--accent), transparent);
}

.dok-process__heading {
  font-family: var(--font-display);
  font-size: clamp(26px, 3vw, 38px);
  font-weight: 600;
  color: var(--text-primary);
  margin: 0;
}

.dok-process__heading em {
  font-style: italic;
  font-family: var(--font-display);
  color: var(--accent);
}

.dok-process__grid {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 0;
  max-width: 960px;
  margin: 0 auto;
}

.dok-process__step {
  flex: 1;
  text-align: center;
  padding: 0 16px;
}

.dok-process__step-icon {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  margin: 0 auto 16px;
  background: var(--accent-bg-solid);
  border: 1px solid var(--accent-border-solid);
  border-radius: 14px;
}

.dok-process__step-icon svg {
  width: 26px;
  height: 26px;
  stroke: var(--accent);
  stroke-width: 2;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.dok-process__step-num {
  position: absolute;
  top: -6px;
  left: -6px;
  width: 22px;
  height: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--accent);
  color: #FFF;
  font-size: 11px;
  font-weight: 700;
  border-radius: 50%;
}

.dok-process__step-title {
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 600;
  color: var(--text-primary);
  margin: 0 0 6px;
}

.dok-process__step-desc {
  font-size: 14px;
  line-height: 1.6;
  color: var(--text-tertiary);
  margin: 0;
}

.dok-process__connector {
  width: 40px;
  min-width: 40px;
  height: 1px;
  margin-top: 32px;
  border-top: 2px dashed var(--bg-tertiary);
}

.dok-process__note {
  max-width: 720px;
  margin: clamp(32px, 4vw, 48px) auto 0;
  text-align: center;
  font-size: 14px;
  color: var(--text-tertiary);
  line-height: 1.7;
}

/* ── CTA Section ── */
.dok-cta {
  background: var(--dark-bg);
  padding: clamp(56px, 7vw, 96px) 0;
}

.dok-cta__inner {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
}

.dok-cta__heading {
  font-family: var(--font-display);
  font-size: clamp(26px, 3vw, 38px);
  font-weight: 600;
  color: var(--dark-text);
  margin: 0 0 16px;
}

.dok-cta__heading em {
  font-style: italic;
  font-family: var(--font-display);
  color: var(--accent-light);
}

.dok-cta__text {
  font-size: 15px;
  line-height: 1.7;
  color: var(--dark-text-secondary);
  margin: 0 0 28px;
}

.dok-cta__buttons {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
  margin-bottom: 20px;
}

.dok-cta__buttons .btn-accent,
.dok-cta__buttons .btn-ghost-dark {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.dok-cta__buttons svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  stroke-width: 2;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.dok-cta__buttons .btn-ghost-dark svg {
  fill: currentColor;
  stroke: none;
}

.dok-cta__trust {
  font-size: 13px;
  color: var(--dark-text-secondary);
  opacity: 0.6;
}

/* ── FAQ Section ── */
.dok-faq {
  background: var(--bg-primary);
  padding: clamp(56px, 7vw, 96px) 0;
}

.dok-faq__header {
  text-align: center;
  margin-bottom: clamp(32px, 4vw, 48px);
}

.dok-faq__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
}

.dok-faq__eyebrow::before,
.dok-faq__eyebrow::after {
  content: '';
  width: 24px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--accent));
}

.dok-faq__eyebrow::after {
  background: linear-gradient(90deg, var(--accent), transparent);
}

.dok-faq__headline {
  font-family: var(--font-display);
  font-size: clamp(26px, 3vw, 38px);
  font-weight: 600;
  color: var(--text-primary);
  margin: 0;
}

.dok-faq__headline em {
  font-style: italic;
  font-family: var(--font-display);
  color: var(--accent);
}

.dok-faq__accordion {
  max-width: 800px;
  margin: 0 auto;
}

/* ── Final CTA ── */
.dok-final-cta {
  background: var(--dark-bg-alt);
  padding: clamp(56px, 7vw, 96px) 0;
}

.dok-final-cta__inner {
  text-align: center;
  max-width: 600px;
  margin: 0 auto;
}

.dok-final-cta__heading {
  font-family: var(--font-display);
  font-size: clamp(26px, 3.5vw, 42px);
  font-weight: 600;
  font-style: italic;
  color: var(--dark-text);
  margin: 0 0 12px;
}

.dok-final-cta__sub {
  font-size: 15px;
  color: var(--dark-text-secondary);
  margin: 0 0 28px;
}

.dok-final-cta__phone {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 20px;
  font-weight: 700;
  padding: 14px 32px;
  margin-bottom: 20px;
  text-decoration: none;
}

.dok-final-cta__phone svg {
  width: 20px;
  height: 20px;
  stroke: currentColor;
  stroke-width: 2;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.dok-final-cta__alt {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-bottom: 20px;
}

.dok-final-cta__alt span {
  font-size: 13px;
  color: var(--dark-text-secondary);
}

.dok-final-cta__alt a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid var(--dark-border);
  color: var(--dark-text-secondary);
  transition: all 0.2s ease;
}

.dok-final-cta__alt a:hover {
  border-color: var(--accent);
  color: var(--accent-light);
}

.dok-final-cta__alt svg {
  width: 16px;
  height: 16px;
  fill: currentColor;
  stroke: none;
}

.dok-final-cta__trust {
  font-size: 13px;
  color: var(--dark-text-secondary);
  opacity: 0.6;
}

/* ── Preview Modal ── */
.dok-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.dok-modal[hidden] {
  display: none;
}

.dok-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

.dok-modal__container {
  position: relative;
  background: var(--bg-elevated);
  border-radius: 16px;
  max-width: 960px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.2);
}

.dok-modal__close {
  position: absolute;
  top: 16px;
  right: 16px;
  z-index: 10;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-secondary);
  border: 1px solid var(--bg-tertiary);
  border-radius: 50%;
  cursor: pointer;
  transition: all 0.2s ease;
}

.dok-modal__close:hover {
  background: var(--bg-tertiary);
}

.dok-modal__close svg {
  width: 16px;
  height: 16px;
  stroke: var(--text-secondary);
  stroke-width: 2;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.dok-modal__body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}

/* Left column — preview */
.dok-modal__preview {
  background: var(--bg-secondary);
  padding: 40px;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  border-radius: 16px 0 0 16px;
}

.dok-modal__preview-page {
  position: relative;
  background: #FFF;
  border-radius: 4px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  padding: 32px 28px;
  width: 100%;
  max-width: 320px;
  min-height: 400px;
}

[data-theme="dark"] .dok-modal__preview-page {
  background: #1E1E1E;
}

.dok-modal__watermark {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(-30deg);
  font-family: var(--font-body);
  font-size: 48px;
  font-weight: 800;
  letter-spacing: 0.1em;
  color: var(--text-muted);
  opacity: 0.07;
  pointer-events: none;
  white-space: nowrap;
}

.dok-modal__toc p {
  font-size: 14px;
  line-height: 1.8;
  color: var(--text-secondary);
  margin: 0;
  padding: 2px 0;
}

.dok-modal__toc-sub {
  padding-left: 16px !important;
  color: var(--text-tertiary) !important;
  font-size: 13px !important;
}

/* Right column — details */
.dok-modal__details {
  padding: 40px;
}

.dok-modal__eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 12px;
}

.dok-modal__title {
  font-family: var(--font-body);
  font-size: 22px;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.3;
  margin: 0 0 12px;
}

.dok-modal__desc {
  font-size: 14px;
  line-height: 1.7;
  color: var(--text-tertiary);
  margin: 0 0 24px;
}

.dok-modal__section {
  margin-bottom: 20px;
}

.dok-modal__section-heading {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  margin: 0 0 8px;
}

.dok-modal__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.dok-modal__list li {
  position: relative;
  padding: 3px 0 3px 20px;
  font-size: 14px;
  line-height: 1.5;
  color: var(--text-secondary);
}

.dok-modal__list li::before {
  content: '•';
  position: absolute;
  left: 4px;
  color: var(--text-muted);
}

.dok-modal__list--check li::before {
  content: '✓';
  color: var(--accent);
  font-weight: 700;
  left: 0;
}

.dok-modal__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin: 20px 0;
  font-size: 13px;
  color: var(--text-muted);
}

.dok-modal__meta-item:first-child {
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 700;
  color: var(--text-primary);
}

.dok-modal__meta-sep {
  opacity: 0.4;
}

.dok-modal__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 12px 24px;
  border-radius: 10px;
  font-weight: 600;
  text-decoration: none;
  font-size: 15px;
}

.dok-modal__btn svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  stroke-width: 2;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.dok-modal__conversion {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--bg-tertiary);
  font-size: 13px;
  color: var(--text-tertiary);
  line-height: 1.5;
}

.dok-modal__conversion p {
  margin: 0 0 4px;
}

.dok-modal__conversion a {
  color: var(--accent);
  text-decoration: none;
  font-weight: 500;
}

.dok-modal__conversion a:hover {
  text-decoration: underline;
}

/* ── Dokumenty Responsive ── */
@media (max-width: 960px) {

  .dok-tabs {
    flex-wrap: wrap;
  }

  .dok-tabs__tab {
    padding: 12px 16px;
    font-size: 13px;
  }

  .dok-vs__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  .dok-hero__cta-group {
    flex-direction: column;
  }

  .dok-hero__cta-group .btn-accent,
  .dok-hero__cta-group .btn-ghost-dark {
    width: 100%;
    justify-content: center;
  }

  .dok-vs__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }

  .dok-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .doc-card {
    padding: 20px;
  }

  .doc-card__title {
    font-size: 18px;
  }

  .dok-filters__input {
    width: 100%;
  }

  .dok-filters {
    flex-direction: column;
    align-items: stretch;
  }

  .dok-filters__chips {
    flex-wrap: wrap;
    gap: 6px;
  }

  .dok-chip {
    white-space: nowrap;
  }

  .dok-process__grid {
    flex-direction: column;
    align-items: center;
    gap: 24px;
  }

  .dok-process__connector {
    width: 1px;
    min-width: 1px;
    height: 24px;
    margin-top: 0;
    border-top: none;
    border-left: 2px dashed var(--bg-tertiary);
  }

  .dok-cta__buttons {
    flex-direction: column;
    align-items: center;
  }

  /* Modal mobile */
  .dok-modal {
    padding: 0;
  }

  .dok-modal__container {
    border-radius: 0;
    max-height: 100vh;
    height: 100%;
  }

  .dok-modal__body {
    grid-template-columns: 1fr;
  }

  .dok-modal__preview {
    border-radius: 0;
    padding: 24px;
  }

  .dok-modal__details {
    padding: 24px;
  }
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  .dok-anim,
  .dok-reveal {
    opacity: 1 !important;
    transform: none !important;
    animation: none !important;
    transition: none !important;
  }
  .doc-card { transition: none !important; }
}
