@charset "UTF-8";
/* =============================================================================
   site.css — warstwa charakteru marki Meble na wymiar G.J
   Podlacza sie PO tokens.css + styles.css. Estetyka: minimal-luxe / editorial-mono.
   Paleta jasna: tlo biale, primary braz #7A5C3E, akcent kremowy #F2EDE4,
   tekst ciemny. Fonty: Fraunces (display) + Source Serif 4 (body).
   ============================================================================= */

/* --- Google Fonts ----------------------------------------------------------- */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,600;0,9..144,700;0,9..144,900;1,9..144,400;1,9..144,700&family=Source+Serif+4:ital,opsz,wght@0,8..60,300;0,8..60,400;0,8..60,600;0,8..60,700;1,8..60,400&display=swap');

/* --- Nadpisanie base: pelny serif body ------------------------------------ */
body { font-family: var(--font-body); }

/* --- Header / brand ------------------------------------------------------- */
.site-header { background: color-mix(in srgb, var(--color-bg) 94%, transparent); }
.brand-name {
  font-family: var(--font-heading);
  font-size: var(--fs-lg);
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--color-primary);
}
.brand-sub {
  font-size: var(--fs-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
  display: block;
}
.nav-link { font-size: var(--fs-sm); letter-spacing: 0.04em; text-transform: uppercase; }
.nav-link:hover { color: var(--color-primary); }
.nav-link--cta {
  background: var(--color-primary);
  color: #fff;
  padding: 10px 20px;
  border-radius: var(--radius-md);
  font-size: var(--fs-sm);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  white-space: nowrap;
  transition: background var(--motion-dur) var(--motion-ease);
}
.nav-link--cta:hover { background: var(--color-primary600); }

/* --- Hero: offset-card ---------------------------------------------------- */
.hero-offset {
  min-height: clamp(560px, 88svh, 900px);
  display: grid;
  grid-template-columns: 1fr;
  position: relative;
  overflow: hidden;
  background: var(--color-surface);
}
@media (min-width: 900px) {
  .hero-offset { grid-template-columns: 1fr 1fr; align-items: center; }
}
.hero-offset__media {
  position: relative;
  min-height: 320px;
  overflow: hidden;
}
@media (min-width: 900px) {
  .hero-offset__media { min-height: 100%; position: absolute; right: 0; top: 0; bottom: 0; width: 55%; }
}
.hero-offset__media img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.hero-kenburns-img {
  animation: kb-zoom 18s linear infinite alternate;
  will-change: transform;
}
@keyframes kb-zoom {
  from { transform: scale(1); }
  to   { transform: scale(1.06); }
}
@media (prefers-reduced-motion: reduce) { .hero-kenburns-img { animation: none; } }

.hero-offset__content {
  position: relative; z-index: 2;
  padding: clamp(40px, 8vw, 80px) clamp(24px, 5vw, 80px);
  display: grid; gap: var(--space-5); align-content: center;
  max-width: 640px;
}
@media (min-width: 900px) { .hero-offset__content { padding-right: clamp(32px, 4vw, 60px); } }

.hero-eyebrow {
  font-size: var(--fs-sm);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-primary);
  font-family: var(--font-body);
  font-weight: 600;
  display: flex; align-items: center; gap: 10px;
}
.hero-eyebrow::before {
  content: "";
  display: block;
  width: 32px; height: 1px;
  background: var(--color-primary);
}
.hero-h1 {
  font-family: var(--font-heading);
  font-size: clamp(2.6rem, 6.5vw, 4.8rem);
  font-weight: 900;
  line-height: 1.0;
  letter-spacing: -0.03em;
  color: var(--text-strong);
  text-wrap: balance;
}
.hero-h1 em {
  font-style: italic;
  color: var(--color-primary);
}
.hero-lead {
  font-size: var(--fs-lg);
  color: var(--text-body);
  line-height: 1.55;
  max-width: 48ch;
}
.hero-ctas {
  display: flex; gap: var(--space-4); flex-wrap: wrap; align-items: center;
}
.btn-hero-primary {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--color-primary);
  color: #fff;
  padding: 14px 28px;
  border-radius: var(--radius-md);
  font-weight: 700;
  font-size: var(--fs-base);
  letter-spacing: 0.01em;
  transition: background var(--motion-dur) var(--motion-ease), transform var(--motion-dur) var(--motion-ease);
  min-height: 52px;
}
.btn-hero-primary:hover { background: var(--color-primary600); transform: translateY(-2px); }
.btn-hero-primary:active { transform: translateY(0); }
.btn-hero-secondary {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--color-primary);
  font-weight: 600;
  font-size: var(--fs-base);
  border-bottom: 1px solid var(--color-primary);
  padding-bottom: 2px;
  transition: opacity var(--motion-dur) var(--motion-ease);
}
.btn-hero-secondary:hover { opacity: 0.7; }

/* Hero trust bar */
.hero-trust {
  display: flex; align-items: center; gap: var(--space-3);
  font-size: var(--fs-sm); color: var(--text-muted);
}
.hero-trust__stars {
  display: flex; gap: 2px;
}
.hero-trust__star {
  width: 14px; height: 14px; fill: #E5B45A;
}
.hero-trust__score { font-weight: 700; color: var(--text-strong); }

/* Offset card block na desktopie */
.hero-offset__card-block {
  position: absolute;
  bottom: var(--space-7);
  right: calc(55% + var(--space-5));
  display: none;
}
@media (min-width: 1100px) { .hero-offset__card-block { display: block; } }
.offset-card {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-6);
  box-shadow: var(--shadow-md);
  min-width: 220px;
  text-align: center;
}
.offset-card__number {
  font-family: var(--font-heading);
  font-size: var(--fs-4xl);
  font-weight: 900;
  color: var(--color-primary);
  line-height: 1;
}
.offset-card__label { font-size: var(--fs-sm); color: var(--text-muted); margin-top: 4px; }

/* --- Sekcje ogolne --------------------------------------------------------- */
.sec-eyebrow {
  font-size: var(--fs-sm);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-primary);
  font-weight: 600;
  display: block;
  margin-bottom: var(--space-3);
}
.sec-title {
  font-family: var(--font-heading);
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 700;
  color: var(--text-strong);
  line-height: 1.1;
  letter-spacing: -0.02em;
  text-wrap: balance;
}
.sec-lead {
  font-size: var(--fs-lg);
  color: var(--text-body);
  max-width: 56ch;
  line-height: 1.55;
  margin-top: var(--space-4);
}
.sec-divider {
  width: 48px; height: 2px;
  background: var(--color-primary);
  margin-block: var(--space-5);
}

/* --- Benefit / manifest ---------------------------------------------------- */
.benefit-section {
  padding-block: clamp(60px, 10vw, 120px);
  background: var(--color-surface);
}
.benefit-grid {
  display: grid;
  gap: var(--space-7);
  align-items: center;
  overflow: hidden; /* zabezpieczenie przed translateX fx-split wychodzącym poza kontener */
}
@media (min-width: 768px) { .benefit-grid { grid-template-columns: 1fr 1fr; } }
.benefit-manifesto {
  font-family: var(--font-heading);
  font-size: clamp(1.5rem, 3.5vw, 2.4rem);
  font-weight: 700;
  line-height: 1.25;
  color: var(--text-strong);
  font-style: italic;
}
.benefit-manifesto strong { font-style: normal; color: var(--color-primary); }
.benefit-items { display: grid; gap: var(--space-5); }
.benefit-item {
  display: flex; gap: var(--space-4); align-items: flex-start;
}
.benefit-item__icon {
  width: 44px; height: 44px; flex: none;
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--color-primary) 10%, transparent);
  display: grid; place-items: center;
}
.benefit-item__icon svg { width: 22px; height: 22px; fill: none; stroke: var(--color-primary); stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.benefit-item__title { font-weight: 700; font-size: var(--fs-base); color: var(--text-strong); margin-bottom: 4px; }
.benefit-item__desc { font-size: var(--fs-base); color: var(--text-body); }

/* --- Uslugi / oferta ------------------------------------------------------- */
.services-section { padding-block: clamp(60px, 10vw, 120px); }
.services-grid {
  display: grid; gap: var(--space-6);
  margin-top: var(--space-8);
}
@media (min-width: 768px) { .services-grid { grid-template-columns: 1fr 1fr; } }
.service-card {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: grid;
  transition: transform var(--motion-dur) var(--motion-ease), box-shadow var(--motion-dur) var(--motion-ease);
}
.service-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.service-card__media { aspect-ratio: 16 / 9; overflow: hidden; }
.service-card__media .media-frame { border-radius: 0; aspect-ratio: 16 / 9; }
.service-card__media img { width: 100%; height: 100%; object-fit: cover; }
.service-card__body { padding: var(--space-6); display: grid; gap: var(--space-3); }
.service-card__title {
  font-family: var(--font-heading);
  font-size: var(--fs-2xl);
  font-weight: 700;
  color: var(--text-strong);
}
.service-card__desc { color: var(--text-body); }
.service-card__link {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--color-primary); font-weight: 600;
  font-size: var(--fs-sm); letter-spacing: 0.04em; text-transform: uppercase;
  margin-top: var(--space-2);
  transition: gap var(--motion-dur) var(--motion-ease);
}
.service-card__link:hover { gap: 10px; }
.service-card__link svg { width: 16px; height: 16px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }

/* --- Jak pracujemy --------------------------------------------------------- */
.process-section {
  padding-block: clamp(60px, 10vw, 120px);
  background: var(--color-primary);
  color: #fff;
}
.process-section .sec-eyebrow { color: color-mix(in srgb, #fff 70%, transparent); }
.process-section .sec-title { color: #fff; }
.process-section .sec-lead { color: rgba(255,255,255,0.8); }
.process-steps {
  display: grid; gap: 0;
  margin-top: var(--space-8);
  counter-reset: steps;
}
@media (min-width: 768px) { .process-steps { grid-template-columns: repeat(4, 1fr); gap: var(--space-5); } }
.process-step {
  padding: var(--space-6) var(--space-5);
  border-top: 1px solid rgba(255,255,255,0.2);
  display: grid; gap: var(--space-3);
}
@media (min-width: 768px) { .process-step { border-top: none; border-left: 1px solid rgba(255,255,255,0.2); padding-top: 0; } }
.process-step:first-child { border-left: none; border-top: none; }
.process-step__num {
  font-family: var(--font-heading);
  font-size: var(--fs-4xl);
  font-weight: 900;
  color: rgba(255,255,255,0.18);
  line-height: 1;
}
.process-step__title {
  font-family: var(--font-heading);
  font-size: var(--fs-xl);
  font-weight: 700;
  color: #fff;
}
.process-step__desc { color: rgba(255,255,255,0.8); font-size: var(--fs-base); }

/* --- Realizacje ------------------------------------------------------------ */
.realizacje-section { padding-block: clamp(60px, 10vw, 120px); }
.realizacje-hero-kafel {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 16 / 9;
  margin-bottom: var(--space-6);
}
.realizacje-hero-kafel img { width: 100%; height: 100%; object-fit: cover; }
.realizacje-hero-kafel__caption {
  position: absolute;
  bottom: var(--space-5); left: var(--space-5);
  background: rgba(10,8,6,0.7);
  color: #fff;
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-sm);
  font-size: var(--fs-sm);
  letter-spacing: 0.04em;
  backdrop-filter: blur(4px);
}
.realizacje-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-5);
}
.realizacja-kafel {
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 4 / 3;
  position: relative;
}
.realizacja-kafel .media-frame { border-radius: 0; aspect-ratio: 4/3; height: 100%; }
.realizacja-kafel img { width: 100%; height: 100%; object-fit: cover; }

/* --- Materialy ------------------------------------------------------------- */
.materials-section {
  padding-block: clamp(60px, 10vw, 120px);
  background: var(--color-surface);
}
.materials-grid {
  display: grid;
  gap: var(--space-5);
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  margin-top: var(--space-8);
}
.material-kafel {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6) var(--space-5);
  text-align: center;
}
.material-kafel__name {
  font-family: var(--font-heading);
  font-size: var(--fs-xl);
  font-weight: 700;
  color: var(--color-primary);
}
.material-kafel__type { font-size: var(--fs-sm); color: var(--text-muted); margin-top: var(--space-2); }
.material-note {
  font-size: var(--fs-sm);
  color: var(--text-muted);
  margin-top: var(--space-4);
  font-style: italic;
}

/* --- Zaufanie / opinie ---------------------------------------------------- */
.trust-section { padding-block: clamp(60px, 10vw, 120px); }
.trust-score-block {
  display: grid; gap: var(--space-7); align-items: center; margin-top: var(--space-8);
}
@media (min-width: 768px) { .trust-score-block { grid-template-columns: auto 1fr; } }
.trust-score-big {
  text-align: center;
}
.trust-score-num {
  font-family: var(--font-heading);
  font-size: clamp(4rem, 10vw, 7rem);
  font-weight: 900;
  color: var(--color-primary);
  line-height: 1;
}
.trust-score-stars {
  display: flex; gap: 4px; justify-content: center; margin-block: var(--space-2);
}
.trust-score-stars svg { width: 22px; height: 22px; fill: #E5B45A; }
.trust-score-count { font-size: var(--fs-sm); color: var(--text-muted); }
.trust-claims { display: grid; gap: var(--space-5); }
.trust-claim { display: flex; gap: var(--space-4); align-items: flex-start; }
.trust-claim__icon { width: 40px; height: 40px; flex: none; border-radius: 50%; background: color-mix(in srgb, var(--color-primary) 10%, transparent); display: grid; place-items: center; }
.trust-claim__icon svg { width: 20px; height: 20px; fill: none; stroke: var(--color-primary); stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.trust-claim__title { font-weight: 700; color: var(--text-strong); margin-bottom: 2px; }
.trust-claim__desc { color: var(--text-body); font-size: var(--fs-base); }
.trust-google-link {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--color-primary); font-weight: 600;
  margin-top: var(--space-4);
  border-bottom: 1px solid var(--color-primary);
  padding-bottom: 2px;
}

/* --- CTA sekcja koncowa --------------------------------------------------- */
.cta-section {
  padding-block: clamp(80px, 12vw, 140px);
  background: var(--color-primary);
  text-align: center;
}
.cta-section .sec-eyebrow { color: rgba(255,255,255,0.7); }
.cta-section .sec-title { color: #fff; margin-bottom: var(--space-4); }
.cta-section .sec-lead { color: rgba(255,255,255,0.85); margin-inline: auto; }
.cta-btns {
  display: flex; gap: var(--space-4); flex-wrap: wrap; justify-content: center;
  margin-top: var(--space-7);
}
.btn-cta-primary {
  display: inline-flex; align-items: center; gap: 8px;
  background: #fff;
  color: var(--color-primary);
  padding: 16px 36px;
  border-radius: var(--radius-md);
  font-weight: 700;
  font-size: var(--fs-base);
  min-height: 56px;
  transition: background var(--motion-dur) var(--motion-ease), transform var(--motion-dur) var(--motion-ease);
}
.btn-cta-primary:hover { background: var(--color-primary100); transform: translateY(-2px); }
.btn-cta-secondary {
  display: inline-flex; align-items: center; gap: 6px;
  color: rgba(255,255,255,0.9);
  font-size: var(--fs-base);
  font-weight: 600;
  border: 1px solid rgba(255,255,255,0.4);
  padding: 16px 28px;
  border-radius: var(--radius-md);
  min-height: 56px;
  transition: border-color var(--motion-dur) var(--motion-ease), background var(--motion-dur) var(--motion-ease);
}
.btn-cta-secondary:hover { border-color: rgba(255,255,255,0.8); background: rgba(255,255,255,0.08); }

/* --- Stopka --------------------------------------------------------------- */
.site-footer {
  background: var(--color-neutral900);
  color: rgba(255,255,255,0.75);
  padding-block: var(--space-9);
}
.footer-grid {
  display: grid; gap: var(--space-8);
}
@media (min-width: 768px) { .footer-grid { grid-template-columns: 1.5fr 1fr 1fr; } }
.footer-brand-name {
  font-family: var(--font-heading);
  font-size: var(--fs-xl);
  font-weight: 700;
  color: #fff;
  margin-bottom: var(--space-3);
}
.footer-brand-desc { font-size: var(--fs-sm); line-height: 1.6; color: rgba(255,255,255,0.6); max-width: 36ch; }
.footer-col-title {
  font-size: var(--fs-sm);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.4);
  margin-bottom: var(--space-4);
  font-weight: 600;
}
.footer-links { display: grid; gap: var(--space-2); }
.footer-links a { color: rgba(255,255,255,0.7); font-size: var(--fs-sm); }
.footer-links a:hover { color: #fff; }
.footer-nap a { color: rgba(255,255,255,0.7); font-size: var(--fs-sm); }
.footer-nap a:hover { color: #fff; }
.footer-phone {
  display: flex; align-items: center; gap: 8px;
  color: #fff; font-weight: 700; font-size: var(--fs-base);
  margin-top: var(--space-3);
}
.footer-phone svg { width: 18px; height: 18px; fill: none; stroke: var(--color-primary); stroke-width: 2; }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.1);
  margin-top: var(--space-8);
  padding-top: var(--space-5);
  font-size: var(--fs-sm);
  color: rgba(255,255,255,0.35);
  display: flex; gap: var(--space-4); flex-wrap: wrap; justify-content: space-between;
}

/* --- Mobile sticky CTA ---------------------------------------------------- */
.mobile-sticky-cta {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 60;
  display: grid; grid-template-columns: 1fr 1fr;
  background: var(--color-bg);
  border-top: 1px solid var(--color-border);
  box-shadow: 0 -4px 20px rgba(0,0,0,0.1);
  transform: translateY(120%);
  transition: transform 0.3s var(--motion-ease);
}
.mobile-sticky-cta.show { transform: translateY(0); }
@media (min-width: 768px) { .mobile-sticky-cta { display: none; } }
.mobile-cta-btn {
  display: flex; align-items: center; justify-content: center; gap: 6px;
  padding: 14px 12px;
  font-weight: 600; font-size: var(--fs-sm);
  text-align: center;
  min-height: 52px;
}
.mobile-cta-btn--primary { background: var(--color-primary); color: #fff; }
.mobile-cta-btn--ghost { color: var(--color-primary); border-right: 1px solid var(--color-border); }
.mobile-cta-btn svg { width: 16px; height: 16px; fill: none; stroke: currentColor; stroke-width: 2; }

/* --- Licznik fx-count ----------------------------------------------------- */
.rating-counter { display: inline; }

/* --- Podstrony: hero slim -------------------------------------------------- */
.page-hero {
  padding-block: clamp(60px, 8vw, 100px);
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
}
.page-hero .breadcrumb {
  display: flex; gap: var(--space-2); align-items: center;
  font-size: var(--fs-sm); color: var(--text-muted);
  margin-bottom: var(--space-4);
}
.page-hero .breadcrumb a { color: var(--color-primary); }
.page-hero .breadcrumb span { color: var(--text-muted); }
.page-hero h1 {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 5vw, 3.8rem);
  font-weight: 900;
  letter-spacing: -0.025em;
  color: var(--text-strong);
}
.page-hero__lead { font-size: var(--fs-lg); color: var(--text-body); margin-top: var(--space-4); max-width: 60ch; }

/* --- Podstrony: formularz kontaktowy -------------------------------------- */
.contact-form { display: grid; gap: var(--space-5); }
.contact-form .field label { font-size: var(--fs-sm); letter-spacing: 0.04em; text-transform: uppercase; color: var(--text-muted); }
.contact-form .field input,
.contact-form .field textarea {
  border-color: var(--color-border);
  background: var(--color-surface);
}
.contact-form .field input:focus,
.contact-form .field textarea:focus {
  border-color: var(--color-primary);
  outline: none;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 15%, transparent);
}
.rodo-label { font-size: var(--fs-sm); color: var(--text-muted); display: flex; gap: 10px; align-items: flex-start; }
.rodo-label input { margin-top: 3px; flex: none; }

/* --- Opinie: agregator ---------------------------------------------------- */
.rating-hero {
  text-align: center;
  padding: var(--space-9) var(--space-5);
  background: var(--color-surface);
}
.rating-hero__num {
  font-family: var(--font-heading);
  font-size: clamp(5rem, 12vw, 9rem);
  font-weight: 900;
  color: var(--color-primary);
  line-height: 1;
}
.rating-hero__stars {
  display: flex; gap: 6px; justify-content: center; margin-block: var(--space-3);
}
.rating-hero__stars svg { width: 28px; height: 28px; fill: #E5B45A; }
.rating-hero__count { font-size: var(--fs-lg); color: var(--text-muted); }
.rating-hero__label { font-size: var(--fs-sm); text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-muted); margin-top: var(--space-2); }

/* --- Oferta subpage cards -------------------------------------------------- */
.oferta-cards { display: grid; gap: var(--space-6); margin-top: var(--space-8); }
@media (min-width: 768px) { .oferta-cards { grid-template-columns: 1fr 1fr; } }
.oferta-card-item {
  display: flex; flex-direction: column;
  border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden;
}
.oferta-card-item__media { aspect-ratio: 3/2; overflow: hidden; }
.oferta-card-item__media .media-frame { border-radius: 0; aspect-ratio: 3/2; height: 100%; }
.oferta-card-item__body { padding: var(--space-6); flex: 1; display: grid; gap: var(--space-3); align-content: start; }
.oferta-card-item__title { font-family: var(--font-heading); font-size: var(--fs-2xl); font-weight: 700; color: var(--text-strong); }
.oferta-card-item__link {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--color-primary); font-weight: 600; font-size: var(--fs-sm);
  text-transform: uppercase; letter-spacing: 0.04em; margin-top: auto; padding-top: var(--space-3);
}

/* --- Service page steps --------------------------------------------------- */
.service-steps { display: grid; gap: var(--space-5); margin-top: var(--space-7); counter-reset: sstep; }
.service-step {
  display: flex; gap: var(--space-5); align-items: flex-start;
  padding: var(--space-5); border: 1px solid var(--color-border); border-radius: var(--radius-lg);
}
.service-step__num {
  font-family: var(--font-heading);
  font-size: var(--fs-3xl);
  font-weight: 900;
  color: var(--color-primary100);
  line-height: 1; flex: none;
  width: 56px; text-align: right;
}
.service-step__body { flex: 1; }
.service-step__title { font-weight: 700; font-size: var(--fs-lg); color: var(--text-strong); margin-bottom: 4px; }
.service-step__desc { color: var(--text-body); }

/* --- Offer grid + offer-card sub-elements ---------------------------------- */
.offer-grid {
  display: grid;
  gap: var(--space-5);
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  margin-top: var(--space-6);
}
/* offer-card jest w styles.css ale bez subklas — dodajemy tu */
.offer-card__icon { width: 44px; height: 44px; margin-bottom: var(--space-3);
  color: var(--color-primary); }
.offer-card__icon svg { width: 100%; height: 100%; }
.offer-card__title { font-family: var(--font-heading); font-size: var(--fs-lg);
  font-weight: 700; color: var(--text-strong); line-height: 1.3; }
.offer-card__desc { font-size: var(--fs-sm); color: var(--text-muted); margin-top: var(--space-2);
  line-height: 1.6; }
.offer-card__link { display: inline-flex; align-items: center; gap: 4px; margin-top: var(--space-3);
  font-size: var(--fs-sm); font-weight: 600; color: var(--color-primary);
  text-transform: uppercase; letter-spacing: 0.04em; }

/* --- FAQ ------------------------------------------------------------------- */
.faq-list { display: grid; gap: 0; margin-top: var(--space-7); }
