/* ========================================
   GLADAN — Design System & Global Styles
   ======================================== */

:root {
  --green: #208b1c;
  --green-light: rgba(32, 139, 28, 0.1);
  --dark: #070309;
  --gray-bg: #f2f2f2;
  --gray-text: #999;
  --gray-mid: #616161;
  --gray-mid2: #666;
  --white: #fff;
  --radius-sm: 8px;
  --radius-md: 16px;
  --radius-lg: 32px;
  --page-padding: 64px;
  --container: 1280px;
  --font-heading: 'Rethink Sans', sans-serif;
  --font-body: 'Manrope', sans-serif;
  --font-inter: 'Inter', sans-serif;

  /* Figma typography tokens */
  --fs-h0: 84px;
  --fs-h1: 64px;
  --fs-h3: 42px;
  --fs-h3-5: 32px;
  --fs-h4: 32px;
  --fs-h5: 24px;
  --fs-h6: 18px;
  --fs-t2: 20px;
  --fs-t3: 16px;
  --fs-t4: 12px;
  --fs-regular: 18px;
  --fs-small: 16px;

  /* Figma spacing & misc tokens */
  --padding-section-md: 80px;
  --padding-section-lg: 112px;
  --border: rgba(7, 3, 9, 0.15);
  --radius-petite: 4px;
}

/* Reset */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  font-size: 18px;
  line-height: 1.5;
  color: var(--dark);
  background: var(--white);
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { text-decoration: none; color: inherit; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
ul { list-style: none; }
hr { border: none; }

/* Container — pure 1280 max-width, no internal padding (padding lives on .section/.footer/.hero) */
.container {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0;
  width: 100%;
}

/* ========================================
   COMPONENTS
   ======================================== */

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 50px;
  padding: 10px 24px;
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  font-weight: 400;
  line-height: 1;
  white-space: nowrap;
  transition: opacity 0.2s, transform 0.15s;
}
.btn:hover { opacity: 0.9; transform: translateY(-1px); }
.btn--primary { background: var(--green); color: var(--white); }
.btn--glass { background: rgba(255,255,255,0.2); color: var(--white); }
.btn--white { background: var(--white); color: var(--dark); padding: 10px 30px; }
.btn--full { width: 100%; }

/* Tagline */
.tagline {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h6);
  color: var(--green);
  text-transform: uppercase;
  line-height: 1.5;
  letter-spacing: normal;
}
.tagline--capitalize { text-transform: capitalize; }

/* Section */
.section { padding: 100px var(--page-padding); }
.section--white { background: var(--white); }
.section--gray { background: var(--gray-bg); }
.section--light { background: var(--gray-bg); }

.section-header { margin-bottom: 80px; }
.section-header--center { text-align: center; }

.section-title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h1);
  line-height: normal;
  margin-top: 16px;
  color: var(--dark);
}
.section-title--left { text-align: left; }

.section-desc {
  font-size: var(--fs-t2);
  font-weight: 400;
  line-height: 1.35;
  margin-top: 10px;
  color: var(--dark);
}

.section-actions {
  display: flex;
  justify-content: center;
  margin-top: 80px;
}
.section-actions .btn--primary {
  font-weight: 500;
  font-size: var(--fs-h6);
  line-height: 1.5;
}

/* ========================================
   NAVBAR
   ======================================== */
.navbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  background: var(--white);
  border-bottom: 1px solid rgba(7,3,9,0.15);
  height: 80px;
}
.navbar__inner {
  max-width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--page-padding);
}
.navbar__left {
  display: flex;
  align-items: center;
  gap: 24px;
}
.navbar__logo img { height: 50px; width: auto; }
.navbar__nav {
  display: flex;
  align-items: center;
  gap: 32px;
  height: 80px;
}
.navbar__link {
  font-family: var(--font-heading);
  font-size: var(--fs-t2);
  font-weight: 400;
  line-height: 1;
  color: var(--dark);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 160px;
  height: 100%;
  padding: 0;
  background: none;
  border: none;
}
.navbar__link svg { width: 24px; height: 24px; flex-shrink: 0; }
.navbar .btn--primary { line-height: 1; }
.navbar__search svg { width: 36px; height: 36px; }
.navbar__link:hover { color: var(--green); }
.navbar__link--active { border-bottom: 2px solid var(--green); }
.navbar__right {
  display: flex;
  align-items: center;
  gap: 32px;
}
.navbar__search {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.navbar__dropdown { position: relative; align-self: stretch; }

/* Dropdown menu — shared */
.navbar__menu {
  position: absolute;
  top: 100%;
  background: var(--white);
  border: 1px solid rgba(7,3,9,0.1);
  border-top: none;
  box-shadow: 0 12px 32px rgba(0,0,0,0.08);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-4px);
  transition: opacity 0.18s, transform 0.18s, visibility 0.18s;
  z-index: 100;
}
.navbar__dropdown:hover > .navbar__menu,
.navbar__dropdown:focus-within > .navbar__menu,
.navbar__dropdown.is-open > .navbar__menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.navbar__dropdown:hover > .navbar__link,
.navbar__dropdown.is-open > .navbar__link { color: var(--green); }

/* Simple dropdown (Produkty, Rozwiązania) */
.navbar__menu--simple {
  left: 0;
  min-width: 300px;
  padding: 12px 0;
  border-radius: 0 0 var(--radius-sm) var(--radius-sm);
}
.navbar__menu-item {
  display: block;
  padding: 12px 24px;
  font-family: var(--font-body);
  font-size: 16px;
  color: var(--dark);
  transition: background 0.15s, color 0.15s;
}
.navbar__menu-item:hover {
  background: var(--green-light);
  color: var(--green);
}
.navbar__menu-item--head {
  font-weight: 700;
  color: var(--green);
  border-bottom: 1px solid rgba(7,3,9,0.08);
  margin-bottom: 8px;
  padding-bottom: 16px;
}

/* Mega menu (Więcej o nas) */
.navbar__menu--mega {
  left: 50%;
  transform: translateX(-50%) translateY(-4px);
  width: 1200px;
  max-width: calc(100vw - 64px);
  display: flex;
  min-height: 400px;
}
.navbar__dropdown:hover > .navbar__menu--mega,
.navbar__dropdown:focus-within > .navbar__menu--mega,
.navbar__dropdown.is-open > .navbar__menu--mega {
  transform: translateX(-50%) translateY(0);
}
.mega-menu__cols {
  flex: 1;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  padding: 32px 32px 32px 48px;
}
.mega-menu__col { display: flex; flex-direction: column; gap: 20px; }
.mega-menu__tagline {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 14px;
  color: var(--green);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.mega-menu__tagline--right { text-align: right; }
.mega-menu__list {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.mega-menu__item {
  display: flex;
  gap: 12px;
  padding: 10px 0;
  color: var(--dark);
  align-items: flex-start;
  transition: color 0.15s;
}
.mega-menu__item:hover { color: var(--green); }
.mega-menu__item > span:last-child { display: flex; flex-direction: column; }
.mega-menu__item strong {
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 16px;
  line-height: 1.3;
}
.mega-menu__item small {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 14px;
  color: var(--gray-mid);
  line-height: 1.4;
  margin-top: 2px;
}
.mega-menu__icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  margin-top: 2px;
}
.mega-menu__blog {
  width: 320px;
  background: rgba(7,3,9,0.04);
  padding: 32px 48px 32px 32px;
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: flex-end;
}
.mega-menu__blog-card {
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: 220px;
  color: var(--dark);
}
.mega-menu__blog-img {
  width: 200px;
  height: 140px;
  object-fit: cover;
  border-radius: 10px;
  align-self: flex-end;
}
.mega-menu__blog-content {
  display: flex;
  flex-direction: column;
  gap: 8px;
  text-align: right;
}
.mega-menu__blog-content strong {
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 16px;
  line-height: 1.3;
}
.mega-menu__blog-content small {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 14px;
  color: var(--gray-mid);
  line-height: 1.4;
}
.mega-menu__blog-cta {
  font-family: var(--font-inter);
  font-size: 16px;
  color: var(--dark);
  margin-top: 8px;
  transition: color 0.15s;
}
.mega-menu__blog-card:hover .mega-menu__blog-cta { color: var(--green); }

/* ========================================
   HERO
   ======================================== */
.hero {
  position: relative;
  height: 900px;
  margin-top: 80px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  padding: 0 var(--page-padding) 100px;
  gap: 120px;
}
.hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.hero__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.5);
}
.hero__content {
  position: relative;
  z-index: 1;
  text-align: center;
  width: 900px;
  max-width: 900px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 40px;
}
.hero__text {
  display: flex;
  flex-direction: column;
  gap: 24px;
  width: 100%;
}
.hero__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h0);
  line-height: normal;
  color: var(--white);
}
.hero__desc {
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--white);
  font-weight: 400;
}
.hero__actions {
  display: flex;
  gap: 16px;
}
.hero__tabs {
  position: relative;
  z-index: 1;
  display: flex;
  gap: 16px;
  max-width: 1024px;
  width: 100%;
}
.hero__tab {
  flex: 1;
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 10px 32px;
  font-family: var(--font-body);
  font-size: 20px;
  color: var(--white);
  border-bottom: 4px solid rgba(255,255,255,0.6);
  background: none;
  transition: border-color 0.2s;
}
.hero__tab--active { border-bottom-color: var(--green); }
.hero__tab:hover { border-bottom-color: var(--green); }

/* ========================================
   ROI GRID — "Od pomiaru do zwrotu" (Figma 25:11066)
   1 big card (left) + 2x2 grid (right). Total height 700px.
   ======================================== */
.roi-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  height: 700px;
  width: 100%;
}
.roi-grid__col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 32px;
  height: 100%;
}
.roi-card {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 24px;
  border-radius: var(--radius-md);
  overflow: hidden;
  color: var(--white);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  text-decoration: none;
  transition: transform 0.3s ease;
  min-width: 0;
  isolation: isolate;
}
.roi-card--big {
  padding: 48px;
  height: 100%;
}
.roi-card:hover { transform: translateY(-4px); }
.roi-card__overlay {
  position: absolute;
  inset: 0;
  background: rgba(7, 3, 9, 0.6);
  z-index: 0;
  border-radius: var(--radius-md);
  pointer-events: none;
}
.roi-card__overlay--big {
  background: rgba(0, 0, 0, 0.4);
}
.roi-card__top,
.roi-card__actions,
.roi-card > .roi-card__link {
  position: relative;
  z-index: 1;
}
.roi-card__top {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.roi-card__step {
  display: inline-block;
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 20px;
  line-height: 1;
  color: var(--white);
}
.roi-card__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 24px;
  line-height: 1.1;
  color: var(--white);
  margin: 0;
}
.roi-card__title--big {
  font-size: 64px;
  line-height: 1;
}
.roi-card__desc {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 16px;
  line-height: 1.35;
  color: var(--white);
  margin: 0;
}
.roi-card__desc--big {
  font-size: 24px;
  line-height: 1.35;
}
.roi-card__top .roi-card__step + .roi-card__title { margin-top: 0; }
.roi-card__top .roi-card__title + .roi-card__desc { margin-top: -4px; }
.roi-card__actions {
  display: flex;
  gap: 24px;
  align-items: center;
}
.roi-card__badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 24px;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 4px;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 18px;
  line-height: 1;
  color: var(--white);
}
.roi-card__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 4px 12px;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 18px;
  line-height: 1;
  color: var(--white);
  border-radius: 4px;
}
.roi-card__chev { display: block; flex: none; }

@media (max-width: 1100px) {
  .roi-card--big .roi-card__title--big { font-size: 48px; }
  .roi-card__title { font-size: 22px; }
  .roi-card__desc--big { font-size: 20px; }
}
@media (max-width: 900px) {
  .roi-grid { height: auto; grid-template-columns: 1fr; }
  .roi-grid__col { grid-template-columns: 1fr; grid-template-rows: none; }
  .roi-card { min-height: 280px; }
  .roi-card--big .roi-card__title--big { font-size: 36px; }
}

/* ========================================
   LOGOS
   ======================================== */
.logos {
  padding: 80px 0;
  background: var(--white);
}
.logos__tagline {
  text-align: center;
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h6);
  line-height: 1.5;
  color: var(--green);
  text-transform: uppercase;
  margin-bottom: 48px;
}
.logos__row {
  position: relative;
  width: 100%;
  overflow: hidden;
  mask-image: linear-gradient(to right, transparent 0, #000 64px, #000 calc(100% - 64px), transparent 100%);
  -webkit-mask-image: linear-gradient(to right, transparent 0, #000 64px, #000 calc(100% - 64px), transparent 100%);
}
.logos__track {
  display: flex;
  width: max-content;
  align-items: center;
  gap: 32px;
  animation: logos-marquee 40s linear infinite;
}
.logos__row:hover .logos__track {
  animation-play-state: paused;
}
.logos__row img,
.logo-placeholder {
  height: 80px;
  width: 156px;
  object-fit: cover;
  flex-shrink: 0;
  transition: opacity 0.3s;
}
@keyframes logos-marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}
.logo-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 20px;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 18px;
  color: var(--dark);
  background: var(--gray-bg);
  border-radius: 8px;
  filter: none;
}

/* ========================================
   DARK CARDS (wyzwania)
   ======================================== */
.cards-row {
  display: grid;
  gap: 32px;
}
.cards-row--4 { grid-template-columns: repeat(4, 1fr); gap: 32px; }
.cards-row--3 { grid-template-columns: repeat(3, 1fr); gap: 40px; }

.card-dark {
  position: relative;
  border-radius: var(--radius-md);
  overflow: hidden;
  padding: 24px;
  height: 400px;
  background-size: cover;
  background-position: center;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  background-size: cover;
  background-position: center;
  color: var(--white);
  transition: transform 0.3s;
}
.card-dark:hover { transform: translateY(-4px); }
.card-dark__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.7);
  border-radius: var(--radius-md);
  z-index: 0;
}
.card-dark__top, .card-dark__link {
  position: relative;
  z-index: 1;
}
.card-dark__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h3-5);
  line-height: normal;
  margin-bottom: 12px;
}
.card-dark__desc {
  font-size: var(--fs-t2);
  font-weight: 400;
  line-height: 1.35;
}
.card-dark__link {
  font-family: var(--font-body);
  font-weight: 700;
  font-size: var(--fs-h6);
  line-height: 1;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

/* ========================================
   LIGHT CARDS (zysk)
   ======================================== */
.card-light {
  background: var(--gray-bg);
  border-radius: var(--radius-md);
  padding: 32px;
  display: flex;
  flex-direction: column;
  min-height: 250px;
}
.card-light .tagline + .card-light__title { margin-top: 20px; }
.card-light .card-light__title + .card-light__desc { margin-top: 16px; }
.card-light__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h3-5);
  line-height: normal;
  color: var(--dark);
  max-width: 248px;
}
.card-light__desc {
  font-family: var(--font-inter);
  font-size: var(--fs-regular);
  line-height: 1.5;
  color: var(--dark);
}

/* ========================================
   WHITE CARDS (dlaczego gladan)
   ======================================== */
.card-white {
  background: var(--white);
  border-radius: var(--radius-md);
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.card-white__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h3);
  line-height: normal;
  color: var(--dark);
}
.card-white__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--dark);
}
.card-white__link {
  font-family: var(--font-body);
  font-weight: 700;
  font-size: var(--fs-h6);
  line-height: 1;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--dark);
  padding: 4px 0;
}
.card-white__link:hover { color: var(--green); }

/* ========================================
   CALCULATOR
   ======================================== */
.calc-header {
  display: flex;
  gap: 0;
  margin-bottom: 80px;
}
.calc-header__left, .calc-header__right {
  flex: 1;
}
.calc-header__right {
  padding: 24px;
  font-family: var(--font-inter);
  font-size: var(--fs-regular);
  line-height: 1.5;
  text-align: left;
  display: flex;
  align-items: center;
}

.calculator {
  display: flex;
  gap: 32px;
  border-radius: var(--radius-md);
}
.calculator__form {
  flex: 1;
  background: var(--gray-bg);
  border-radius: var(--radius-md);
  padding: 24px 32px;
  display: flex;
  flex-direction: column;
  gap: 32px;
}
.calculator__heading h3 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h3);
  line-height: normal;
  color: var(--dark);
}
.calculator__heading p {
  font-family: var(--font-body);
  font-size: var(--fs-h6);
  line-height: 1.5;
  margin-top: 10px;
}

/* Sliders */
.calc-slider { display: flex; flex-direction: column; gap: 12px; }
.calc-slider__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}
.calc-slider__label {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 16px;
  color: var(--dark);
  text-transform: uppercase;
}
.calc-slider__value {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 24px;
  color: var(--green);
}
.calc-slider__input {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 8px;
  border-radius: 8px;
  background: #d9d9d9;
  outline: none;
}
.calc-slider__input::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--green);
  cursor: pointer;
  border: 3px solid var(--white);
  box-shadow: 0 0 0 2px var(--green);
}
.calc-slider__input::-moz-range-thumb {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--green);
  cursor: pointer;
  border: 3px solid var(--white);
  box-shadow: 0 0 0 2px var(--green);
}
.calc-slider__range {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  color: var(--gray-text);
}

.calculator__divider {
  height: 1px;
  background: var(--green);
}
.calculator__tip {
  background: var(--green-light);
  border-left: 4px solid var(--green);
  border-radius: var(--radius-sm);
  padding: 16px 20px;
  font-size: 16px;
}
.calculator__tip strong {
  font-weight: 800;
}

/* Results */
.calculator__results {
  width: 632px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 16px;
}
.calc-main-result {
  background: var(--green);
  border-radius: var(--radius-md);
  padding: 40px;
  color: var(--white);
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.calc-main-result__label {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 16px;
}
.calc-main-result__bar {
  width: 4px;
  height: 40px;
  background: var(--white);
  border-radius: 100px;
}
.calc-main-result__value {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 64px;
  line-height: 1;
}
.calc-main-result__note {
  font-size: 16px;
  opacity: 0.9;
}

.calc-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.calc-card {
  background: var(--gray-bg);
  border-radius: var(--radius-sm);
  padding: 14px 26px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.calc-card__label {
  font-weight: 600;
  font-size: 16px;
  color: var(--gray-mid2);
}
.calc-card__value {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 32px;
  color: var(--dark);
}
.calc-card__note {
  font-family: var(--font-inter);
  font-size: 14px;
  color: var(--gray-text);
}

.calc-actions {
  display: flex;
  gap: 16px;
}
.calc-action-col {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.calc-action-col__hint {
  font-size: 12px;
  color: var(--gray-mid);
  text-align: center;
}

/* ========================================
   SECTORS
   ======================================== */
.sectors {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
  text-align: center;
}
.sector {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}
.sector__icon {
  width: 96px;
  height: 96px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.sector__icon img { width: 96px; height: 96px; }
.sector__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h3-5);
  line-height: normal;
  color: var(--dark);
  min-height: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: -8px;
}
.sector__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--dark);
}

/* ========================================
   TESTIMONIAL
   ======================================== */
.testimonial {
  position: relative;
}
.testimonial .container {
  position: relative;
}
.testimonial__content {
  max-width: 900px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 32px;
  text-align: center;
}
.testimonial__logo img {
  height: 48px;
  width: auto;
}
.testimonial__quote {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 36px;
  line-height: 1.5;
  color: var(--dark);
}
.testimonial__author {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.testimonial__avatar {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  object-fit: cover;
}
.testimonial__name {
  font-size: 20px;
  font-weight: 700;
}
.testimonial__role {
  font-size: 16px;
  color: var(--dark);
}
.testimonial__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0.5;
  transition: opacity 0.2s;
}
.testimonial__nav:hover { opacity: 1; }
.testimonial__nav--prev { left: 0; }
.testimonial__nav--next { right: 0; }

/* ========================================
   BLOG CARDS
   ======================================== */
.blog-card {
  background: var(--white);
  border-radius: var(--radius-md);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  height: 610px;
}
.blog-card__img {
  height: 266px;
  overflow: hidden;
}
.blog-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s;
}
.blog-card:hover .blog-card__img img { transform: scale(1.05); }
.blog-card__body {
  flex: 1;
  padding: 24px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.blog-card__meta {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 20px;
}
.blog-card__tag {
  background: var(--green);
  color: var(--white);
  font-weight: 600;
  font-size: 16px;
  padding: 4px 10px;
  border-radius: 4px;
  line-height: 1.5;
}
.blog-card__time {
  font-weight: 600;
  font-size: 16px;
  color: var(--dark);
}
.blog-card__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 32px;
  line-height: 1;
  margin-bottom: 16px;
}
.blog-card__desc {
  font-size: 20px;
  color: var(--dark);
  margin-bottom: 20px;
}
.blog-card__link {
  font-weight: 700;
  font-size: 18px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--dark);
}
.blog-card__link:hover { color: var(--green); }

/* ========================================
   CTA BANNER
   ======================================== */
.cta-banner {
  background: var(--green);
  border-radius: var(--radius-lg);
  padding: 64px;
  min-height: 352px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 40px;
  color: var(--white);
}
.cta-banner__text { display: flex; flex-direction: column; gap: 10px; align-items: center; }
.cta-banner__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h1);
  line-height: normal;
  margin: 0;
}
.cta-banner__desc {
  font-family: var(--font-body);
  font-size: 24px;
  line-height: 1.5;
  margin: 0;
}

/* ========================================
   FOOTER
   ======================================== */
.footer {
  background: var(--gray-bg);
  padding: 80px var(--page-padding);
}
.footer__newsletter {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 80px;
}
.newsletter-form .btn--primary { padding: 10px 30px; }
.footer__newsletter-title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 42px;
  line-height: 1;
  color: var(--dark);
}
.footer__newsletter-text { width: 560px; max-width: 560px; }
.footer__newsletter-text p {
  font-size: 16px;
  line-height: 1.5;
  margin-top: 4px;
}
.newsletter-form {
  display: flex;
  gap: 20px;
}
.newsletter-form__input {
  width: 300px;
  padding: 8px 12px;
  border-radius: var(--radius-sm);
  border: none;
  background: var(--white);
  font-family: var(--font-body);
  font-size: 16px;
  color: var(--dark);
  height: 50px;
}
.newsletter-form__input::placeholder { color: #616161; }
.footer__consent {
  display: block;
  margin-top: 4px;
  font-size: 12px;
  color: var(--gray-mid);
}
.footer__tagline { font-family: var(--font-inter); font-size: 16px; line-height: 1.5; }
.footer__credits {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 32px;
  gap: 24px;
}
.footer__copyright {
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 16px;
  color: var(--gray-text);
}
.footer__divider {
  height: 1px;
  background: rgba(7,3,9,0.15);
  margin: 0;
}
.footer__links {
  display: flex;
  justify-content: space-between;
  gap: 32px;
  padding: 60px 0;
}
.footer__brand {
  width: 245px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.footer__brand p {
  font-family: var(--font-inter);
  font-size: 16px;
  line-height: 1.5;
}
.footer__logo { height: auto; }
.footer__social {
  display: flex;
  gap: 12px;
}
.footer__social a { display: flex; }
.footer__social a:hover svg { color: var(--green); }
.footer__col {
  min-width: 180px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
}
.footer__col-title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 24px;
  line-height: 1;
  color: var(--dark);
  margin-bottom: 16px;
  width: 100%;
}
.footer__list { width: 100%; line-height: 1; }
.footer__list li { padding: 8px 0; line-height: 1; }
.footer__list a {
  font-size: 16px;
  line-height: 1;
  color: var(--dark);
  white-space: nowrap;
  transition: color 0.2s;
}
.footer__list a:hover { color: var(--green); }
.footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 32px;
  color: var(--gray-text);
  font-weight: 700;
  font-size: 16px;
}
.footer__legal {
  display: flex;
  gap: 32px;
}
.footer__legal a {
  font-weight: 400;
  font-size: 16px;
  line-height: 1;
  color: var(--gray-text);
}
.footer__legal a:hover { color: var(--green); }

/* ========================================
   PRODUCT HEADER (split layout for product detail pages)
   ======================================== */
.product-header {
  background: var(--white);
  padding: 80px 0;
}
.product-header__wrap {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--page-padding);
  display: flex;
  gap: 80px;
  align-items: flex-start;
}
.product-header__main {
  flex: 1;
  min-width: 0;
}
.product-header__breadcrumb {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: var(--font-body);
  font-size: 16px;
  color: var(--green);
  margin-bottom: 48px;
}
.product-header__breadcrumb a,
.product-header__breadcrumb span { color: var(--green); }
.product-header__breadcrumb > * { display: inline-flex; align-items: center; }
.product-header__breadcrumb svg {
  width: 20px;
  height: 20px;
  opacity: 0.7;
  margin: 0 4px;
}
.product-header__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 50px;
  line-height: 1.1;
  color: var(--dark);
  margin-bottom: 16px;
}
.product-header__desc {
  font-family: var(--font-body);
  font-size: 20px;
  line-height: 1.4;
  color: var(--dark);
  margin-bottom: 32px;
}
.product-header__desc strong { font-weight: 700; }
.product-header__features {
  background: #dde8dd;
  border-radius: var(--radius-sm);
  padding: 32px;
  margin-bottom: 32px;
}
.product-header__features h2 {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 24px;
  color: var(--dark);
  margin-bottom: 16px;
}
.product-header__feature-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  padding: 8px 0;
}
.product-header__feature-col { display: flex; flex-direction: column; gap: 16px; }
.product-header__feature {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  font-size: 16px;
  color: var(--dark);
}
.product-header__feature svg {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  margin-top: 2px;
  color: var(--green);
}
.product-header__faq h2 {
  font-family: 'Sora', var(--font-heading);
  font-weight: 700;
  font-size: 32px;
  letter-spacing: -0.32px;
  color: var(--dark);
  margin: 24px 0 16px;
}
.product-header__accordion {
  background: var(--gray-bg);
  border-radius: 8px;
  margin-bottom: 16px;
  overflow: hidden;
}
.product-header__accordion-btn {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 24px;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 24px;
  line-height: 1;
  color: var(--dark);
  transition: color 0.2s;
}
.product-header__accordion-btn > span:first-child { flex: 1; }
.product-header__accordion-btn svg {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  transition: transform 0.25s;
  color: var(--green);
}
.product-header__accordion.is-open .product-header__accordion-btn svg {
  transform: rotate(45deg);
}
.product-header__accordion-body {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
  padding: 0 24px;
}
.product-header__accordion.is-open .product-header__accordion-body {
  padding: 0 24px 24px;
}
.product-header__accordion-body p {
  font-family: var(--font-body);
  font-size: 20px;
  line-height: 1.4;
  color: var(--dark);
}
.product-header__side {
  width: 360px;
  flex-shrink: 0;
  position: sticky;
  top: 100px;
}
.product-header__media {
  position: relative;
  width: 100%;
  aspect-ratio: 360/190;
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: 24px;
}
.product-header__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.product-header__media::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.5);
  z-index: 1;
}
.product-header__play {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 64px;
  height: 64px;
  background: rgba(255,255,255,0.9);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  cursor: pointer;
  border: none;
}
.product-header__play::after {
  content: '';
  width: 0;
  height: 0;
  margin-left: 6px;
  border-top: 12px solid transparent;
  border-bottom: 12px solid transparent;
  border-left: 18px solid var(--green);
}
.product-header__product-name {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 42px;
  line-height: 1;
  color: var(--dark);
  margin-bottom: 16px;
}
.product-header__stars {
  display: flex;
  gap: 4px;
  color: #f5a623;
  margin-bottom: 12px;
}
.product-header__stars svg { width: 20px; height: 20px; fill: currentColor; }
.product-header__review {
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.5;
  color: var(--dark);
  margin-bottom: 24px;
}
.product-header__cta-box {
  background: rgba(7,3,9,0.05);
  border-radius: 8px;
  padding: 16px 24px;
  font-family: var(--font-body);
  font-size: 18px;
  color: var(--dark);
  line-height: 1.4;
  margin-bottom: 16px;
}
.product-header__cta-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  height: 50px;
  background: var(--gray-mid);
  color: var(--white);
  border-radius: 8px;
  border: none;
  font-family: var(--font-body);
  font-size: 18px;
  cursor: pointer;
  transition: background 0.2s;
  margin-bottom: 16px;
  text-decoration: none;
}
.product-header__cta-btn:hover { background: var(--dark); }
.product-header__cta-btn--primary {
  background: var(--green);
}
.product-header__cta-btn--primary:hover { background: #1a6e17; }
.product-header__cta-btn svg { width: 20px; height: 20px; }
@media (max-width: 1100px) {
  .product-header__wrap { flex-direction: column; gap: 48px; }
  .product-header__side { width: 100%; position: static; }
  .product-header__title { font-size: 36px; }
  .product-header__feature-grid { grid-template-columns: 1fr; }
}

/* ========================================
   CONTACT SECTION (per Figma)
   ======================================== */
.contact-section {
  background: var(--white);
  padding: 112px 0;
}
.contact-section .contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
}
.contact-info { display: flex; flex-direction: column; gap: 8px; }
.contact-info__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 64px;
  line-height: 1.05;
  color: var(--dark);
  margin: 16px 0 24px;
}
.contact-info__desc {
  font-family: var(--font-body);
  font-size: 20px;
  color: var(--dark);
  margin-bottom: 32px;
}
.contact-info__list { list-style: none; padding: 8px 0; display: flex; flex-direction: column; gap: 16px; }
.contact-info__item {
  display: flex;
  gap: 16px;
  align-items: center;
  font-family: var(--font-body);
  font-size: 20px;
  color: var(--dark);
}
.contact-info__item svg { width: 24px; height: 24px; color: var(--green); flex-shrink: 0; }
.contact-info__item a { color: var(--dark); }
.contact-info__item a:hover { color: var(--green); }

.contact-form {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.contact-form .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.contact-form .form-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.contact-form label, .contact-form legend {
  font-family: var(--font-body);
  font-size: 20px;
  color: var(--dark);
  padding: 0;
}
.contact-form .form-input,
.contact-form .form-select,
.contact-form .form-textarea {
  background: #ebf7f4;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  padding: 8px 12px;
  font-family: var(--font-body);
  font-size: 16px;
  color: var(--dark);
  transition: border-color 0.2s;
}
.contact-form .form-input,
.contact-form .form-select { height: 50px; }
.contact-form .form-input:focus,
.contact-form .form-select:focus,
.contact-form .form-textarea:focus {
  outline: none;
  border-color: var(--green);
}
.contact-form .form-textarea { min-height: 180px; resize: vertical; }
.form-radios { border: none; padding: 16px 0; margin: 0; display: flex; flex-direction: column; gap: 16px; }
.form-radios legend { margin-bottom: 0; }
.form-radios__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.form-radio {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-body);
  font-size: 16px;
  color: var(--dark);
  cursor: pointer;
}
.form-radio input[type="radio"] {
  width: 24px;
  height: 24px;
  accent-color: var(--green);
  margin: 8px;
  cursor: pointer;
}
.form-consent {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 16px;
  color: var(--dark);
  cursor: pointer;
}
.form-consent input[type="checkbox"] {
  width: 24px;
  height: 24px;
  accent-color: var(--green);
  margin: 8px;
  cursor: pointer;
}
.form-consent a { color: var(--green); text-decoration: underline; }

@media (max-width: 900px) {
  .contact-section .contact-grid { grid-template-columns: 1fr; gap: 48px; }
  .contact-info__title { font-size: 40px; }
  .contact-form .form-row { grid-template-columns: 1fr; }
  .form-radios__grid { grid-template-columns: 1fr; }
}

/* ========================================
   PAGE HERO (subpages)
   ======================================== */
.page-hero {
  position: relative;
  min-height: 500px;
  margin-top: 80px;
  display: flex;
  align-items: center;
  padding: 80px var(--page-padding);
  overflow: hidden;
}
.page-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.page-hero__bg > * {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.page-hero__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.55);
}
.page-hero__content {
  position: relative;
  z-index: 1;
  max-width: 700px;
}
.page-hero__content--center {
  max-width: 900px;
  margin: 0 auto;
  text-align: center;
}
.page-hero .breadcrumb {
  margin-bottom: 24px;
}
.page-hero__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 64px;
  line-height: 1.05;
  color: var(--white);
  margin-bottom: 16px;
}
.page-hero__desc {
  font-size: 20px;
  color: var(--white);
  opacity: 0.9;
  margin-bottom: 32px;
}
.page-hero__actions {
  display: flex;
  gap: 16px;
}
.page-hero__badge {
  display: inline-block;
  background: var(--green);
  color: var(--white);
  padding: 6px 16px;
  border-radius: var(--radius-sm);
  font-weight: 700;
  font-size: 14px;
  text-transform: uppercase;
  margin-bottom: 16px;
}
.page-hero__side {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
}
.page-hero--split {
  display: flex;
  justify-content: space-between;
  gap: 64px;
}
.page-hero--split .page-hero__content {
  flex: 1;
}
.page-hero--split .page-hero__side {
  flex: 0 0 400px;
}

/* Header/98 — contained card hero (Figma pattern dla hub pages) */
.page-hero--card {
  display: block;
  padding: 80px var(--page-padding);
  min-height: 0;
  background: var(--white);
  margin-top: 80px;
  overflow: visible;
}
.page-hero--card .page-hero__inner {
  position: relative;
  max-width: var(--container);
  margin: 0 auto;
  height: 640px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 0 64px;
}
.page-hero--card .page-hero__bg { position: absolute; inset: 0; z-index: 0; }
.page-hero--card .page-hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--radius-lg);
}
.page-hero--card .page-hero__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
  border-radius: var(--radius-lg);
}
.page-hero--card .page-hero__content {
  position: relative;
  z-index: 1;
  max-width: 100%;
  width: 100%;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 32px;
}
.page-hero--card .page-hero__text {
  display: flex;
  flex-direction: column;
  gap: 24px;
  width: 100%;
}
.page-hero--card .page-hero__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h0);
  line-height: normal;
  color: var(--white);
  margin: 0;
}
.page-hero--card .page-hero__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--white);
  opacity: 1;
  margin: 0;
}
.page-hero--card .page-hero__actions {
  display: flex;
  gap: 16px;
  justify-content: center;
}
.btn--glass-strong { background: rgba(255,255,255,0.4); color: var(--white); }

/* Resource card (Layout/237 — outlined card with icon, title, desc, CTA button)
   Used on baza-wiedzy hub. Border green, content centered, button at bottom. */
.resource-card {
  border: 4px solid var(--green);
  border-radius: var(--radius-md, 16px);
  background: transparent;
  overflow: hidden;
  min-height: 369px;
  display: flex;
  flex-direction: column;
}
.resource-card__inner {
  flex: 1 0 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  padding: 32px;
  gap: 24px;
  text-align: center;
  height: 100%;
}
.resource-card__icon {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.resource-card__icon img { width: 48px; height: 48px; }
.resource-card__text {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%;
}
.resource-card__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 32px;
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.resource-card__desc {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 20px;
  line-height: normal;
  color: var(--dark);
  margin: 0;
}

/* Tag pill (Layout/400, Blog tag etc.) */
.tag {
  display: inline-flex;
  align-items: center;
  background: var(--green);
  color: var(--white);
  padding: 4px 10px;
  border-radius: var(--radius-petite);
  font-family: var(--font-body);
  font-weight: 600;
  font-size: var(--fs-t3);
  line-height: 1.5;
  white-space: nowrap;
}

/* Product step card (Layout/400 — Sensory/Transmisja/Analiza/Efekt) */
.step-cards-row {
  display: flex;
  gap: 26.67px;
  width: 100%;
  height: 400px;
}
.step-card {
  flex: 1 0 0;
  min-width: 0;
  background: #dde8dd;
  border-radius: var(--radius-md);
  overflow: clip;
  display: flex;
  flex-direction: column;
  height: 100%;
}
.step-card__inner {
  display: flex;
  flex: 1;
  flex-direction: column;
  justify-content: space-between;
  padding: 24px;
}
.step-card__top { display: flex; flex-direction: column; gap: 20px; }
.step-card__content { display: flex; flex-direction: column; gap: 16px; }
.step-card__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h3-5);
  line-height: normal;
  color: var(--dark);
}
.step-card__desc {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--dark);
}
.step-card__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 40px;
  padding: 4px 0;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: var(--fs-h6);
  line-height: 1;
  color: var(--dark);
}
.step-card__link svg { width: 24px; height: 24px; }

/* Layout/526 — 7 ROZWIĄZAŃ asym grid */
.solutions-frame {
  display: flex;
  flex-direction: column;
  gap: 32px;
  width: 100%;
}
.solutions-top {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  width: 100%;
  gap: 32px;
}
.solutions-top__number {
  display: flex;
  align-items: flex-end;
  color: var(--green);
  white-space: nowrap;
  flex-shrink: 0;
}
.solutions-top__digit {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 200px;
  line-height: normal;
}
.solutions-top__label {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h3);
  line-height: normal;
  margin-bottom: 24px;
}
.solutions-card {
  position: relative;
  border-radius: var(--radius-md);
  overflow: clip;
  padding: 32px;
  color: var(--white);
  display: flex;
  flex-direction: column;
  gap: 24px;
  background: #2c2c2c;
  flex-shrink: 0;
  text-decoration: none;
}
.solutions-card__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: var(--radius-md);
}
.solutions-card__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.solutions-card__bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(7, 3, 9, 0.6);
}
.solutions-card > *:not(.solutions-card__bg) { position: relative; z-index: 1; }
.solutions-card__top { display: flex; flex-direction: column; gap: 16px; }
.solutions-card__tag {
  display: inline-flex;
  align-self: flex-start;
  background: var(--green);
  color: var(--white);
  padding: 4px 12px;
  border-radius: 4.8px;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 19.2px;
  line-height: 1.5;
  white-space: nowrap;
}
.solutions-card__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h3);
  line-height: normal;
}
.solutions-card__desc {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: var(--fs-t2);
  line-height: 1.35;
}
.solutions-card__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 4px 0;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: var(--fs-h6);
  line-height: 1;
  color: var(--white);
}
.solutions-card__link svg { width: 24px; height: 24px; }
.solutions-card--feature {
  width: 842px;
  height: 255px;
  flex-shrink: 0;
  justify-content: center;
}
.solutions-card--feature .solutions-card__top { gap: 8px; }
.solutions-card--feature .solutions-card__title {
  font-family: 'Sora', var(--font-heading);
  font-size: 40px;
  letter-spacing: -0.4px;
  line-height: 1.3;
}
.solutions-row {
  display: flex;
  gap: 32px;
  width: 100%;
  height: 851px;
}
.solutions-col {
  flex: 1 0 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 32px;
  height: 100%;
}
.solutions-col > .solutions-card:not(.solutions-card--h547):not(.solutions-card--h512):not(.solutions-card--h420) {
  flex: 1 1 auto;
  height: auto;
}
.solutions-card--h547 { height: 547px; }
.solutions-card--h512 { height: 512px; }
.solutions-card--h420 { height: 420px; }

/* Layout/356 — 3 alternating Feature blocks (image+content split) */
.feature-block {
  padding: 60px var(--page-padding);
  background: var(--white);
  width: 100%;
}
.feature-block--gray { background: var(--gray-bg); }
.feature-block--top-border { border-top: 1px solid var(--border); }
.feature-block__container {
  max-width: var(--container);
  margin: 0 auto;
  padding-bottom: 100px;
  display: flex;
  flex-direction: column;
  gap: 48px;
}
.feature-block__info {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 64px;
  gap: 24px;
}
.feature-block__info-tag {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h6);
  line-height: 1.5;
  text-transform: uppercase;
  color: var(--dark);
  white-space: nowrap;
}
.feature-block__info-dot {
  font-family: var(--font-inter);
  font-size: var(--fs-t2);
  color: var(--green);
  line-height: 1.5;
}
.feature-block__card {
  width: 100%;
  height: 640px;
  border-radius: var(--radius-lg);
  overflow: clip;
  display: flex;
}
.feature-block--reverse .feature-block__card { flex-direction: row-reverse; }
.feature-block__content,
.feature-block__image {
  flex: 1 0 0;
  min-width: 0;
  height: 100%;
}
.feature-block__content {
  padding: 48px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 32px;
}
.feature-block__content-top { display: flex; flex-direction: column; gap: 8px; }
.feature-block__content-text { display: flex; flex-direction: column; gap: 24px; }
.feature-block__tagline {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h6);
  line-height: 1.5;
  color: var(--green);
  text-transform: uppercase;
}
.feature-block__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 50px;
  line-height: normal;
  color: var(--dark);
}
.feature-block__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--dark);
}
.feature-block__image {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: clip;
}
.feature-block__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.feature-block .btn { align-self: flex-start; }

/* Testimonial/39 — 4+2+1 layout */
.testimonials-section { padding: 100px var(--page-padding); background: var(--gray-bg); }
.testimonials-section__container {
  max-width: var(--container);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 80px;
  align-items: center;
}
.testimonials-section__title {
  max-width: 768px;
  width: 100%;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.testimonials-section__heading {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h1);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.testimonials-section__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--dark);
  margin: 0;
}
.testimonials-frame {
  display: flex;
  flex-direction: column;
  gap: 32px;
  width: 100%;
}
.testimonials-row {
  display: flex;
  width: 100%;
}
.testimonials-row--four { justify-content: space-between; }
.testimonials-row--mixed { gap: 32px; }
.opinia {
  background: var(--white);
  padding: 24px;
  border-radius: var(--radius-sm);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  overflow: clip;
}
.opinia__top { display: flex; flex-direction: column; gap: 16px; align-items: center; width: 100%; }
.opinia__logo { display: flex; align-items: center; justify-content: center; height: 60px; }
.opinia__logo img { max-height: 60px; width: auto; object-fit: contain; }
.opinia__stars { display: flex; gap: 4.7px; }
.opinia__stars svg { width: 21.18px; height: 21.18px; flex-shrink: 0; }
.opinia__quote {
  font-family: var(--font-body);
  font-size: var(--fs-t3);
  line-height: normal;
  color: var(--dark);
  text-align: center;
  margin: 0;
}
.opinia--small { width: 300px; height: 300px; }
.opinia--medium {
  width: 288px;
  height: 367px;
  border-radius: var(--radius-md);
  gap: 16px;
}
.opinia--medium .opinia__top { gap: 8px; }
.opinia--medium .opinia__logo { height: 80px; }
.opinia--medium .opinia__logo img { max-height: 80px; }
.opinia__avatar-text {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  width: 100%;
}
.opinia__avatar-name {
  font-family: var(--font-body);
  font-weight: 600;
  font-size: var(--fs-t3);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.opinia__avatar-role {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: var(--fs-t4);
  line-height: 1.5;
  color: var(--dark);
  margin: 0;
}
.opinia--wide {
  flex: 1 1 640px;
  width: 640px;
  border-radius: var(--radius-md);
  padding: 24px 32px;
  align-items: stretch;
  height: auto;
  gap: 16px;
}
.opinia--wide__head { display: flex; align-items: center; justify-content: space-between; width: 100%; }
.opinia--wide__head .opinia__logo { height: 56px; }
.opinia--wide__head .opinia__logo img { max-height: 56px; }
.opinia--wide__head .opinia__stars svg { width: 24px; height: 24px; }
.opinia--wide .opinia__quote {
  font-size: var(--fs-t2);
  line-height: normal;
  text-align: left;
}
.opinia--wide__avatar { display: flex; gap: 20px; align-items: flex-start; width: 100%; }
.opinia--wide__avatar-img {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}
.opinia--wide__avatar-text { display: flex; flex-direction: column; align-items: flex-start; flex: 1; }
.opinia--wide__avatar-text .opinia__avatar-name {
  font-size: var(--fs-t2);
  text-align: left;
}
.opinia--wide__avatar-text .opinia__avatar-role {
  font-size: var(--fs-t2);
  text-align: left;
}

/* Layout/521 — 4 green solution cards 296×300 */
.solution-cards-row {
  display: flex;
  gap: 32px;
  height: 300px;
  width: 100%;
}
.solution-card {
  flex: 1 0 0;
  min-width: 0;
  background: var(--green);
  border-radius: var(--radius-md);
  overflow: clip;
  padding: 24px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
  text-decoration: none;
  color: var(--white);
}
.solution-card__top { display: flex; flex-direction: column; gap: 24px; }
.solution-card__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h3-5);
  line-height: normal;
  color: var(--white);
  max-width: 244px;
}
.solution-card__desc {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--white);
}
.solution-card__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 4px 0;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: var(--fs-h6);
  line-height: 1;
  color: var(--white);
}
.solution-card__link svg { width: 24px; height: 24px; }

/* Layout/526 — extension: numbered cards (01-07) + bottom-wide variant */
.solutions-card__num {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h1);
  line-height: normal;
  color: var(--green);
  margin: 0;
}
.solutions-row--rozw { height: 1034px; }
.solutions-card--wide-bottom {
  width: 100%;
  height: auto;
}
.solutions-card--wide-bottom .solutions-card__title {
  font-family: 'Sora', var(--font-heading);
  font-size: 40px;
  letter-spacing: -0.4px;
  line-height: 1.3;
}

/* Layout/89 — info section with decorative gear (Rozwiązania) */
.info-section {
  position: relative;
  background: var(--gray-bg);
  padding: 100px var(--page-padding);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 80px;
}
.info-section__gear {
  position: absolute;
  width: 200px;
  height: 200px;
  top: 88px;
  left: calc(50% + 224px);
  transform: rotate(-16deg);
  color: var(--green);
  opacity: 0.85;
  pointer-events: none;
}
.info-section__container {
  position: relative;
  width: 800px;
  max-width: var(--container);
  margin: 0 auto;
}
.info-section__content {
  display: flex;
  flex-direction: column;
  gap: 40px;
  align-items: center;
  width: 100%;
}
.info-section__title-block {
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: center;
  width: 100%;
}
.info-section__title-block h2 {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h1);
  line-height: normal;
  text-align: center;
  color: var(--dark);
  margin: 0;
  width: 100%;
}
.info-section__text-block {
  display: flex;
  flex-direction: column;
  gap: 32px;
  align-items: center;
  width: 100%;
}
.info-section__text-block p {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  text-align: center;
  color: var(--dark);
  margin: 0;
  width: 100%;
}
.info-section__actions {
  display: flex;
  gap: 24px;
  align-items: center;
}
.btn-text {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-inter);
  font-weight: 500;
  font-size: var(--fs-regular);
  line-height: 1.5;
  color: var(--dark);
  text-decoration: none;
}
.btn-text svg { width: 24px; height: 24px; }

/* Layout/121 — Timeline (Sektory Hub) */
.timeline-section {
  background: var(--white);
  padding: 100px var(--page-padding);
}
.timeline-section__container {
  max-width: var(--container);
  margin: 0 auto;
  display: flex;
  gap: 80px;
  align-items: flex-start;
}
.timeline-section__left,
.timeline-section__right {
  flex: 1 0 0;
  min-width: 0;
}
.timeline-section__left {
  display: flex;
  flex-direction: column;
  gap: 32px;
  align-items: flex-start;
}
.timeline-section__title-block {
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: flex-start;
  width: 100%;
}
.timeline-section__heading {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h1);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.timeline {
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: 100%;
}
.timeline-item {
  display: flex;
  gap: 40px;
  align-items: flex-start;
  width: 100%;
}
.timeline-item__icon-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex-shrink: 0;
  gap: 16px;
}
.timeline-item__bullet {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.timeline-item__bullet::before {
  content: "";
  display: block;
  width: 32px;
  height: 30.5px;
  background: var(--green);
  border-radius: 24.6px;
}
.timeline-item__line {
  width: 1px;
  height: 100px;
  background: var(--border);
  flex-shrink: 0;
}
.timeline-item:last-child .timeline-item__line { display: none; }
.timeline-item__content {
  flex: 1 0 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.timeline-item__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h3-5);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.timeline-item__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--dark);
  margin: 0;
}

/* Outline button (white bg with gray border) */
.btn--outline {
  background: var(--white);
  color: var(--dark);
  border: 1px solid #999;
}

/* Layout/239 — section title + 3 icon columns + CTA button */
.icons-section {
  background: var(--gray-bg);
  padding: 100px var(--page-padding);
}
.icons-section__container {
  max-width: var(--container);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 80px;
  align-items: center;
}
.icons-section__title {
  max-width: 768px;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: center;
  text-align: center;
}
.icons-section__title-tag {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h6);
  line-height: 1.5;
  color: var(--green);
  text-transform: uppercase;
}
.icons-section__title-content { display: flex; flex-direction: column; gap: 24px; align-items: center; width: 100%; }
.icons-section__heading {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h1);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.icons-section__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--dark);
  margin: 0;
}
.icons-row {
  display: flex;
  gap: 32px;
  width: 100%;
  justify-content: center;
}
.icon-column {
  flex: 1 0 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: center;
  text-align: center;
}
.icon-column__icon {
  width: 96px;
  height: 96px;
  flex-shrink: 0;
}
.icon-column__icon img { width: 100%; height: 100%; }
.icon-column__content { display: flex; flex-direction: column; gap: 16px; align-items: center; width: 100%; }
.icon-column__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h3-5);
  line-height: normal;
  color: var(--dark);
  margin: 0;
  min-height: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.icon-column__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--dark);
  margin: 0;
}

/* Layout/526 — Sektory variant: 6 cards asym, no numbers, height 634 */
.solutions-row--sektory { height: 634px; }
.solutions-card--h356 { height: 356px; }
.solutions-card--h246 { height: 246px; }
.solutions-card--h301 { height: 301px; }

/* Stats/44 — split 2 stats blocks */
.stats-section {
  background: var(--white);
  padding: 100px var(--page-padding);
}
.stats-section__container {
  max-width: var(--container);
  margin: 0 auto;
  display: flex;
  gap: 80px;
  align-items: center;
}
.stats-section__left,
.stats-section__right {
  flex: 1 0 0;
  min-width: 0;
}
.stats-section__left {
  display: flex;
  flex-direction: column;
  gap: 32px;
  align-items: flex-start;
}
.stats-section__heading {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h1);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.stats-section__right {
  display: flex;
  flex-direction: column;
  gap: 32px;
}
.stat-block {
  background: #ebf7f4;
  border-radius: var(--radius-lg);
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 48px;
}
.stat-block__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h3-5);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.stat-block__content { display: flex; flex-direction: column; gap: 16px; }
.stat-block__value {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h0);
  line-height: normal;
  color: var(--dark);
  text-align: right;
  margin: 0;
}
.stat-block__divider { height: 1px; background: var(--border); width: 100%; }
.stat-block__caption {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--dark);
  text-align: right;
  margin: 0;
}

/* Layout/513 — 4 alternating numbered rows (Twoja Rola hub) */
.numbered-rows-section {
  background: var(--white);
  padding: 100px var(--page-padding);
}
.numbered-rows-section__container {
  max-width: var(--container);
  margin: 0 auto;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 100px;
}
.numbered-rows-section__head {
  display: flex;
  flex-direction: column;
  gap: 32px;
  align-items: center;
  padding-bottom: 100px;
}
.numbered-rows-section__title-block {
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: center;
  width: 100%;
}
.numbered-rows-section__heading {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h1);
  line-height: normal;
  color: var(--dark);
  text-align: center;
  margin: 0;
}
.numbered-rows-section__rows {
  display: flex;
  flex-direction: column;
  gap: 100px;
}
.numbered-row {
  display: flex;
  flex-direction: column;
  gap: 80px;
  width: 100%;
}
.numbered-row__content {
  display: flex;
  flex-direction: column;
  gap: 32px;
  align-items: flex-start;
}
.numbered-row--right .numbered-row__content { align-items: flex-end; }
.numbered-row__top {
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: 100%;
  color: var(--green);
}
.numbered-row--right .numbered-row__top { align-items: flex-end; }
.numbered-row__num {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 100px;
  line-height: normal;
  margin: 0;
}
.numbered-row__heading {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 50px;
  line-height: normal;
  text-transform: uppercase;
  margin: 0;
  width: 100%;
}
.numbered-row--right .numbered-row__heading { text-align: right; }
.numbered-row__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--dark);
  margin: 0;
  width: 100%;
}
.numbered-row--right .numbered-row__desc { text-align: right; }
.numbered-row__image {
  width: 100%;
  height: 392px;
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.numbered-row__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Layout/378 — complex card grid (Twoja Rola Branże) */
.industries-section {
  background: var(--gray-bg);
  padding: 100px var(--page-padding);
}
.industries-section__container {
  max-width: var(--container);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 80px;
  align-items: center;
}
.industries-section__title {
  max-width: 768px;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: center;
  text-align: center;
}
.industries-grid {
  display: flex;
  gap: 32px;
  width: 100%;
  align-items: stretch;
}
.industry-card-big {
  flex: 1 0 0;
  min-width: 0;
  background: var(--gray-bg);
  border-radius: var(--radius-md);
  overflow: clip;
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
}
.industry-card-big__image {
  width: 100%;
  height: 300px;
  flex-shrink: 0;
}
.industry-card-big__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.industry-card-big__content {
  background: var(--white);
  padding: 48px;
  display: flex;
  flex-direction: column;
  gap: 32px;
  flex: 1;
}
.industry-card-big__top { display: flex; flex-direction: column; gap: 8px; }
.industry-card-big__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 50px;
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.industry-card-big__desc { font-family: var(--font-body); font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0; }
.industry-card-big__actions { display: flex; gap: 24px; align-items: center; }
.btn--neutral { background: #b4b3b5; color: var(--white); }
.industries-grid__col {
  flex: 1 0 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 32px;
}
.industries-grid__row { display: flex; gap: 32px; height: 350px; }
.industry-card-small {
  flex: 1 0 0;
  min-width: 0;
  background: var(--white);
  border-radius: var(--radius-md);
  overflow: clip;
  padding: 24px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  text-decoration: none;
  color: inherit;
}
.industry-card-small__top { display: flex; flex-direction: column; gap: 24px; }
.industry-card-small__icon {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.industry-card-small__icon img { width: 100%; height: 100%; }
.industry-card-small__content { display: flex; flex-direction: column; gap: 16px; }
.industry-card-small__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h3-5);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.industry-card-small__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t3);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.industry-card-small__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: var(--fs-h6);
  line-height: 1;
  color: var(--dark);
}
.industry-card-small__link svg { width: 24px; height: 24px; }
.industry-card-wide {
  width: 100%;
  background: var(--white);
  border-radius: var(--radius-md);
  overflow: clip;
  display: flex;
  align-items: stretch;
  text-decoration: none;
  color: inherit;
}
.industry-card-wide__image {
  flex: 1 0 0;
  min-width: 0;
}
.industry-card-wide__image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.industry-card-wide__content {
  flex: 1 0 0;
  min-width: 0;
  padding: 32px 24px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 32px;
}
.industry-card-wide__top { display: flex; flex-direction: column; gap: 32px; }
.industry-card-wide__heading {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h3-5);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.industry-card-wide__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--dark);
  margin: 0;
}

/* Layout/93 — Pilot section (border card with 2 list items + 2 buttons) */
.pilot-section {
  background: var(--white);
  padding: 100px var(--page-padding);
}
.pilot-section__container {
  max-width: var(--container);
  margin: 0 auto;
  border: 1px solid var(--green);
  border-radius: var(--radius-lg);
  padding: 64px;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.pilot-section__content {
  width: 1000px;
  max-width: 100%;
  display: flex;
  flex-direction: column;
  gap: 100px;
  align-items: center;
}
.pilot-section__head {
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: center;
  width: 100%;
}
.pilot-section__text-block {
  display: flex;
  flex-direction: column;
  gap: 32px;
  align-items: center;
  width: 100%;
  text-align: center;
}
.pilot-section__heading {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h1);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.pilot-section__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--dark);
  margin: 0;
}
.pilot-section__bottom {
  display: flex;
  flex-direction: column;
  gap: 60px;
  align-items: center;
  width: 100%;
}
.pilot-section__list-row { display: flex; gap: 64px; justify-content: center; width: 100%; }
.pilot-list-item {
  background: #dde8dd;
  border-radius: var(--radius-md);
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: flex-start;
  width: 400px;
}
.pilot-list-item__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h3-5);
  line-height: normal;
  color: var(--green);
  margin: 0;
  width: 100%;
}
.pilot-list-item__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--dark);
  margin: 0;
  width: 100%;
}
.pilot-section__actions { display: flex; gap: 24px; align-items: center; }

/* Contact/14 — 3 contact cards + image */
.contact-section {
  background: var(--white);
  padding: 100px var(--page-padding);
}
.contact-section__container {
  max-width: var(--container);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 80px;
  align-items: center;
}
.contact-section__title {
  max-width: 768px;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: center;
  text-align: center;
}
.contact-section__content {
  display: flex;
  flex-direction: column;
  gap: 80px;
  align-items: stretch;
  width: 100%;
}
.contact-section__row {
  display: flex;
  gap: 40px;
  width: 100%;
}
.contact-section .contact-card {
  flex: 1 0 0;
  min-width: 0;
  background: var(--green);
  border: none;
  border-radius: var(--radius-md);
  padding: 24px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  text-align: left;
  text-decoration: none;
  color: var(--white);
}
.contact-section .contact-card__icon {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--white);
}
.contact-section .contact-card__icon img { width: 100%; height: 100%; filter: brightness(0) invert(1); }
.contact-section .contact-card__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h3-5);
  line-height: normal;
  color: var(--white);
  margin: 0;
}
.contact-section .contact-card__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--white);
  margin: 0;
}
.contact-section .contact-card__value {
  font-family: var(--font-body);
  font-weight: 700;
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--white);
  margin: 0;
  text-decoration: none;
}
.contact-section .contact-card__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: var(--fs-t2);
  line-height: normal;
  color: var(--white);
  text-decoration: none;
}
.contact-section .contact-card__link svg { width: 24px; height: 24px; }
.contact-section__image {
  width: 100%;
  height: 516px;
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.contact-section__image img { width: 100%; height: 100%; object-fit: cover; }

/* ========================================
   BREADCRUMB
   ======================================== */
.breadcrumb {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 16px;
  color: rgba(255,255,255,0.8);
}
.breadcrumb a {
  color: rgba(255,255,255,0.8);
  transition: color 0.2s;
}
.breadcrumb a:hover { color: var(--white); }
.breadcrumb > * { display: inline-flex; align-items: center; gap: 4px; }
.breadcrumb svg {
  width: 16px;
  height: 16px;
  opacity: 0.6;
  flex-shrink: 0;
}
.breadcrumb span:last-child { font-weight: 600; }
.breadcrumb--dark { color: var(--green); }
.breadcrumb--dark a { color: var(--green); }
.breadcrumb--dark a:hover { color: var(--dark); }
.breadcrumb--dark svg { color: var(--green); opacity: 1; }

/* ========================================
   TWO COLUMN LAYOUT
   ======================================== */
.two-col {
  display: flex;
  gap: 64px;
  align-items: center;
}
.two-col--reverse { flex-direction: row-reverse; }
.two-col__text { flex: 1; }
.two-col__media {
  flex: 1;
  border-radius: var(--radius-md);
  overflow: hidden;
  min-height: 400px;
  position: relative;
}
.two-col__media > * {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  inset: 0;
}
.two-col__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 42px;
  line-height: 1.05;
  margin-bottom: 16px;
}
.two-col__desc {
  font-size: 20px;
  line-height: 1.5;
  margin-bottom: 24px;
}

/* ========================================
   FEATURE GRID
   ======================================== */
.feature-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
.feature-grid--4 { grid-template-columns: repeat(4, 1fr); }
.feature-grid--3 { grid-template-columns: repeat(3, 1fr); }
.feature-grid--2 { grid-template-columns: repeat(2, 1fr); }
.timeline-section--reverse { flex-direction: row-reverse; }
.timeline-section--reverse .timeline-section__container { flex-direction: row-reverse; }
.testimonial-split__arrow { background: var(--green); color: var(--white); width: 48px; height: 48px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; border: none; cursor: pointer; }
.testimonial-split__arrow svg { width: 24px; height: 24px; }
.testimonial-split__dots { display: flex; gap: 14px; }
.testimonial-split__dot { width: 14px; height: 14px; border-radius: 50%; background: rgba(7,3,9,0.2); border: none; padding: 0; cursor: pointer; }
.testimonial-split__dot.is-active { background: var(--green); }
.testimonial-split__avatar-content { display: flex; flex-direction: column; }
.layout365-side__actions { display: flex; gap: 24px; align-items: center; }
.result-card__link { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-body); font-weight: 700; font-size: 18px; color: var(--dark); text-decoration: none; }
.result-card__link svg { width: 24px; height: 24px; }
.result-card__link:hover { opacity: 0.85; }

.feature-item {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.feature-item--card {
  background: var(--gray-bg);
  border-radius: var(--radius-md);
  padding: 32px;
}
.feature-item--white {
  background: var(--white);
  border-radius: var(--radius-md);
  padding: 32px;
}
/* Mint-tone card variant — Figma Layout/29 with bg #dde8dd, plain icon (no tile) */
.feature-item--mint {
  background: #dde8dd;
  border-radius: var(--radius-md);
  padding: 24px;
  gap: 16px;
}
.feature-item--mint .feature-item__icon {
  width: 48px;
  height: 48px;
  background: transparent;
  border-radius: 0;
  color: var(--dark);
  padding: 0;
}
.feature-item--mint .feature-item__icon img,
.feature-item--mint .feature-item__icon svg { width: 100%; height: 100%; display: block; }
.feature-item--mint .feature-item__title { font-size: 32px; font-weight: 700; }
.feature-item--mint .feature-item__desc { font-size: 20px; line-height: normal; }
.feature-item__icon {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--green-light);
  border-radius: var(--radius-sm);
  color: var(--green);
}
.feature-item__num {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 64px;
  color: var(--green);
  line-height: 1;
}
.feature-item__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 24px;
  color: var(--dark);
}
.feature-item__desc {
  font-size: 18px;
  line-height: 1.5;
  color: var(--dark);
}

/* ========================================
   NUMBERED STEPS
   ======================================== */
.steps { counter-reset: step; }
.step {
  display: flex;
  gap: 32px;
  align-items: flex-start;
  padding: 40px 0;
  border-bottom: 1px solid rgba(7,3,9,0.1);
}
.step:last-child { border-bottom: none; }
.step__num {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 80px;
  color: var(--green);
  line-height: 0.8;
  flex-shrink: 0;
  width: 100px;
}
.step__content { flex: 1; }
.step__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 32px;
  margin-bottom: 12px;
}
.step__desc {
  font-size: 18px;
  line-height: 1.6;
}

/* ========================================
   STATS ROW
   ======================================== */
.stats-row {
  display: flex;
  gap: 32px;
}
.stat {
  flex: 1;
  text-align: center;
  padding: 32px;
}
.stat--card {
  background: var(--gray-bg);
  border-radius: var(--radius-md);
}
.stat__value {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 48px;
  color: var(--green);
  line-height: 1;
  margin-bottom: 8px;
}
.stat__label {
  font-size: 18px;
  color: var(--dark);
}
.stat__desc {
  font-size: 16px;
  color: var(--gray-mid);
  margin-top: 8px;
}

/* ========================================
   ACCORDION / FAQ
   ======================================== */
.accordion { max-width: 800px; margin: 0 auto; }
.accordion__item {
  border-bottom: 1px solid rgba(7,3,9,0.1);
}
.accordion__trigger {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 24px 0;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 20px;
  color: var(--dark);
  text-align: left;
  background: none;
  border: none;
  cursor: pointer;
}
.accordion__trigger svg { transition: transform 0.3s; flex-shrink: 0; }
.accordion__trigger.active svg { transform: rotate(180deg); }
.accordion__body {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}
.accordion__body-inner {
  padding: 0 0 24px;
  font-size: 18px;
  line-height: 1.6;
  color: var(--gray-mid);
}

/* ========================================
   CONTACT FORM
   ======================================== */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
}
.contact-info {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.contact-info__item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 16px;
}
.contact-info__icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  color: var(--green);
}

.form-group {
  margin-bottom: 20px;
}
.form-group label {
  display: block;
  font-weight: 600;
  font-size: 14px;
  margin-bottom: 6px;
  color: var(--dark);
}
.form-input, .form-select, .form-textarea {
  width: 100%;
  padding: 12px 16px;
  border: 1px solid rgba(7,3,9,0.15);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: 16px;
  color: var(--dark);
  background: var(--white);
  transition: border-color 0.2s;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  outline: none;
  border-color: var(--green);
}
.form-textarea { resize: vertical; min-height: 120px; }
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.form-checkbox {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 14px;
  color: var(--gray-mid);
  margin-bottom: 20px;
}
.form-checkbox input { margin-top: 3px; }

/* ========================================
   CONTACT CARDS
   ======================================== */
.contact-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
.contact-card {
  background: var(--white);
  border: 1px solid rgba(7,3,9,0.1);
  border-radius: var(--radius-md);
  padding: 32px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}
.contact-card__icon {
  width: 48px;
  height: 48px;
  color: var(--green);
}
.contact-card__title {
  font-weight: 700;
  font-size: 20px;
}
.contact-card__value {
  font-size: 16px;
  color: var(--gray-mid);
}
.contact-card__link {
  color: var(--green);
  font-weight: 600;
  font-size: 16px;
}

/* ========================================
   MAP
   ======================================== */
.map-container {
  width: 100%;
  height: 400px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--gray-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gray-text);
  font-size: 18px;
}

/* ========================================
   ARTICLE LAYOUT
   ======================================== */
.article-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 64px;
}
.article-sidebar {
  position: sticky;
  top: 100px;
  align-self: start;
}
.article-sidebar__title {
  font-weight: 700;
  font-size: 16px;
  margin-bottom: 16px;
  color: var(--gray-mid);
}
.article-sidebar__list li {
  padding: 8px 0;
}
.article-sidebar__list a {
  font-size: 16px;
  color: var(--dark);
  transition: color 0.2s;
}
.article-sidebar__list a:hover { color: var(--green); }
.article-sidebar__list a.active {
  color: var(--green);
  font-weight: 700;
}

.article-content {
  max-width: 800px;
}
.article-content h2 {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 32px;
  margin: 48px 0 16px;
}
.article-content h3 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 24px;
  margin: 32px 0 12px;
}
.article-content p {
  font-size: 18px;
  line-height: 1.8;
  margin-bottom: 16px;
}
.article-content ul, .article-content ol {
  margin: 16px 0;
  padding-left: 24px;
}
.article-content li {
  font-size: 18px;
  line-height: 1.8;
  margin-bottom: 8px;
  list-style: disc;
}
.article-content img {
  width: 100%;
  border-radius: var(--radius-md);
  margin: 32px 0;
}
.article-content blockquote {
  border-left: 4px solid var(--green);
  padding: 16px 24px;
  margin: 32px 0;
  background: var(--green-light);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  font-size: 18px;
  font-style: italic;
}
.article-meta {
  display: flex;
  gap: 24px;
  align-items: center;
  padding: 24px 0;
  border-bottom: 1px solid rgba(7,3,9,0.1);
  margin-bottom: 40px;
}
.article-meta__author {
  display: flex;
  align-items: center;
  gap: 12px;
}
.article-meta__avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--gray-bg);
}
.article-meta__date {
  color: var(--gray-mid);
  font-size: 16px;
}

/* ========================================
   TEAM GRID
   ======================================== */
.team-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
}
.team-member {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
.team-member__photo {
  width: 200px;
  height: 200px;
  border-radius: 50%;
  overflow: hidden;
  background: var(--gray-bg);
}
.team-member__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.team-member__name {
  font-weight: 700;
  font-size: 20px;
}
.team-member__role {
  font-size: 16px;
  color: var(--gray-mid);
}

/* ========================================
   PROBLEM LIST
   ======================================== */
.problem-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.problem-item {
  padding: 20px 24px;
  border: 1px solid rgba(7,3,9,0.1);
  border-radius: var(--radius-sm);
  margin-bottom: -1px;
  font-weight: 700;
  font-size: 20px;
  transition: background 0.2s;
}
.problem-item:hover {
  background: var(--green-light);
}

/* ========================================
   CHECKLIST
   ======================================== */
.checklist {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.checklist__item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 18px;
  line-height: 1.5;
}
.checklist__icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  color: var(--green);
}

/* ========================================
   PRODUCT SPECS TABLE
   ======================================== */
.spec-table {
  width: 100%;
  border-collapse: collapse;
}
.spec-table th, .spec-table td {
  padding: 16px 24px;
  text-align: left;
  border-bottom: 1px solid rgba(7,3,9,0.1);
  font-size: 16px;
}
.spec-table th {
  font-weight: 700;
  background: var(--gray-bg);
  width: 40%;
}
.spec-table tr:last-child th,
.spec-table tr:last-child td {
  border-bottom: none;
}

/* ========================================
   PILL TABS
   ======================================== */
.pill-tabs {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.pill-tab {
  padding: 8px 20px;
  border-radius: 100px;
  font-size: 16px;
  font-weight: 600;
  background: var(--gray-bg);
  color: var(--dark);
  border: none;
  cursor: pointer;
  transition: all 0.2s;
}
.pill-tab--active, .pill-tab:hover {
  background: var(--green);
  color: var(--white);
}

/* ========================================
   CARDS ROW --2
   ======================================== */
.cards-row--2 { grid-template-columns: repeat(2, 1fr); }

/* ========================================
   SECTION VARIANTS
   ======================================== */
.section--dark {
  background: var(--dark);
  color: var(--white);
}
.section--dark .section-title,
.section--dark .section-desc,
.section--dark .tagline { color: var(--white); }
.section--dark .tagline { opacity: 0.7; }

.section--green {
  background: var(--green);
  color: var(--white);
}
.section--green .section-title { color: var(--white); }

/* ========================================
   RESPONSIVE
   ======================================== */
@media (max-width: 1200px) {
  :root { --page-padding: 40px; }
  .hero__title { font-size: 60px; }
  .section-title { font-size: 48px; }
  .cards-row--4 { grid-template-columns: repeat(2, 1fr); }
  .calculator { flex-direction: column; }
  .calculator__results { width: 100%; }
  .calc-header { flex-direction: column; gap: 24px; }
  .calc-header__right { text-align: left; padding: 0; }
  .sectors { grid-template-columns: repeat(2, 1fr); }
  .footer__links { flex-wrap: wrap; }
  .cta-banner__title { font-size: 48px; }
  .page-hero__title { font-size: 48px; }
  .page-hero--split { flex-direction: column; }
  .page-hero--split .page-hero__side { flex: none; width: 100%; }
  .two-col { gap: 40px; }
  .two-col__title { font-size: 36px; }
  .feature-grid { grid-template-columns: repeat(2, 1fr); }
  .feature-grid--4 { grid-template-columns: repeat(2, 1fr); }
  .stats-row { flex-wrap: wrap; }
  .stat { flex: 1 1 45%; }
  .contact-grid { grid-template-columns: 1fr; }
  .article-layout { grid-template-columns: 1fr; }
  .article-sidebar { position: static; }
  .team-grid { grid-template-columns: repeat(2, 1fr); }
  .cards-row--2 { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  :root { --page-padding: 24px; }
  .hero { height: auto; min-height: 100vh; padding-bottom: 60px; gap: 60px; }
  .hero__title { font-size: 42px; }
  .hero__tabs { flex-direction: column; gap: 0; }
  .hero__tab { height: 60px; }
  .section { padding: 60px 0; }
  .section-header { margin-bottom: 40px; }
  .section-title { font-size: 36px; }
  .section-desc { font-size: 18px; }
  .cards-row--4, .cards-row--3 { grid-template-columns: 1fr; }
  .card-dark { height: 300px; }
  .card-white__title { font-size: 32px; }
  .sectors { grid-template-columns: 1fr; }
  .calc-grid { grid-template-columns: 1fr; }
  .calc-main-result__value { font-size: 42px; }
  .calc-actions { flex-direction: column; }
  .testimonial__quote { font-size: 24px; }
  .blog-card { height: auto; }
  .cta-banner { padding: 40px 24px; }
  .cta-banner__title { font-size: 32px; }
  .footer__newsletter { flex-direction: column; gap: 24px; align-items: flex-start; }
  .newsletter-form { flex-direction: column; }
  .newsletter-form__input { width: 100%; }
  .footer__links { flex-direction: column; }
  .footer__bottom { flex-direction: column; gap: 16px; text-align: center; }
  .footer__legal { flex-direction: column; gap: 12px; }
  .navbar__nav { display: none; }
  .logos__row { justify-content: center; }
  .logos__row img { height: 36px; }
  .page-hero { min-height: 400px; padding: 60px var(--page-padding); }
  .page-hero__title { font-size: 36px; }
  .page-hero__actions { flex-direction: column; }
  .two-col { flex-direction: column; gap: 32px; }
  .two-col--reverse { flex-direction: column; }
  .two-col__media { min-height: 250px; }
  .two-col__title { font-size: 28px; }
  .feature-grid, .feature-grid--4, .feature-grid--2 { grid-template-columns: 1fr; }
  .step { flex-direction: column; gap: 16px; }
  .step__num { font-size: 48px; width: auto; }
  .stats-row { flex-direction: column; }
  .stat { flex: none; }
  .contact-cards { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .team-grid { grid-template-columns: 1fr; }
  .stat__value { font-size: 36px; }
}

/* ============================================================
   Persona: Kierownik UR (Figma 25:17152)
   ============================================================ */

.persona-challenges-section { background: var(--white); padding: 100px var(--page-padding); }
.persona-challenges-section__container { max-width: var(--container); margin: 0 auto; display: flex; flex-direction: column; gap: 80px; align-items: center; }
.persona-challenges-section__title { max-width: 768px; width: 100%; display: flex; flex-direction: column; gap: 16px; align-items: center; text-align: center; }
.persona-challenges-section__title-content { display: flex; flex-direction: column; gap: 24px; align-items: center; width: 100%; }
.persona-challenges-section__heading { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h1); line-height: normal; color: var(--dark); margin: 0; }
.persona-challenges-section__desc { font-family: var(--font-body); font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0; }
.green-cards-row { display: flex; gap: 32px; width: 100%; height: 420px; }
.green-card { flex: 1 0 0; min-width: 0; background: var(--green); border-radius: var(--radius-md); padding: 24px 16px; display: flex; flex-direction: column; justify-content: space-between; color: var(--white); overflow: hidden; box-sizing: border-box; }
.green-card__inner { padding: 0 16px; display: flex; flex-direction: column; justify-content: space-between; flex: 1; min-height: 0; }
.green-card__top { display: flex; flex-direction: column; gap: 16px; }
.green-card__icon { width: 48px; height: 48px; flex-shrink: 0; }
.green-card__icon img { width: 100%; height: 100%; display: block; }
.green-card__content { display: flex; flex-direction: column; gap: 12px; }
.green-card__title { font-family: var(--font-heading); font-weight: 700; font-size: var(--fs-h3-5); line-height: normal; color: var(--white); margin: 0; }
.green-card__desc { font-family: var(--font-body); font-size: var(--fs-t3); line-height: normal; color: var(--white); margin: 0; }
.green-card__link { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-body); font-weight: 700; font-size: 18px; color: var(--white); text-decoration: none; }
.green-card__link svg { width: 24px; height: 24px; }
.green-card--wide { flex: none; width: 640px; padding: 24px 32px; }
.green-card--wide .green-card__inner { padding: 0; }
.green-card--wide .green-card__top { gap: 24px; }
.green-card--wide .green-card__title { font-size: 50px; }
.green-card--wide .green-card__desc { font-size: var(--fs-t2); }
.green-card__tag { display: inline-flex; align-items: center; justify-content: center; background: var(--white); color: var(--dark); padding: 12px 10px; border-radius: var(--radius-sm); font-family: var(--font-body); font-weight: 600; font-size: 16px; line-height: 1.5; align-self: flex-start; }
.green-card__actions { display: flex; gap: 24px; align-items: center; }

.persona-tools-section { background: var(--white); padding: 100px var(--page-padding); }
.persona-tools-section--gray { background: var(--gray-bg); }
.hero-2col--reverse { flex-direction: row-reverse; }
.testimonial-split__container { max-width: var(--container); margin: 0 auto; }
.persona-tools-section__container { max-width: var(--container); margin: 0 auto; display: flex; flex-direction: column; gap: 80px; align-items: center; }
.persona-tools-section__title { max-width: 768px; width: 100%; display: flex; flex-direction: column; gap: 16px; align-items: center; text-align: center; }
.persona-tools-section__title-content { display: flex; flex-direction: column; gap: 24px; align-items: center; width: 100%; }
.persona-tools-section__heading { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h1); line-height: normal; color: var(--dark); margin: 0; }
.persona-tools-section__desc { font-family: var(--font-body); font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0; }
.persona-tools-row { display: flex; gap: 48px; align-items: flex-start; width: 100%; }
.persona-tool-col { flex: 1 0 0; min-width: 0; display: flex; flex-direction: column; gap: 24px; align-items: center; text-align: center; }
.persona-tool-col__icon { width: 48px; height: 48px; flex-shrink: 0; }
.persona-tool-col__icon img { width: 100%; height: 100%; display: block; }
.persona-tool-col__title { font-family: var(--font-heading); font-weight: 700; font-size: var(--fs-h3); line-height: normal; color: var(--green); margin: 0; }
.persona-tool-col__desc { font-family: var(--font-body); font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0; }
.persona-tools-actions { display: flex; gap: 30px; align-items: center; }

.persona-benefits-section { background: var(--gray-bg); padding: 100px var(--page-padding); }
.persona-benefits-section__container { max-width: var(--container); margin: 0 auto; display: flex; flex-direction: column; gap: 80px; align-items: center; }
.persona-benefits-section__title { max-width: 768px; width: 100%; display: flex; flex-direction: column; gap: 16px; align-items: center; text-align: center; }
.persona-benefits-section__title-content { display: flex; flex-direction: column; gap: 24px; align-items: center; width: 100%; }
.persona-benefits-section__heading { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h1); line-height: normal; color: var(--dark); margin: 0; }
.persona-benefits-section__desc { font-family: var(--font-body); font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0; }
.benefit-image-row { display: flex; gap: 40px; width: 100%; justify-content: space-between; height: 550px; }
.benefit-image-card { width: 400px; background: var(--white); border-radius: var(--radius-md); overflow: hidden; display: flex; flex-direction: column; box-sizing: border-box; }
.benefit-image-card__image { width: 100%; aspect-ratio: 405/270; overflow: hidden; flex-shrink: 0; }
.benefit-image-card__image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.benefit-image-card__body { flex: 1; padding: 24px; display: flex; flex-direction: column; justify-content: center; gap: 16px; text-align: center; }
.benefit-image-card__title { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h3-5); line-height: normal; color: var(--dark); margin: 0; }
.benefit-image-card__desc { font-family: var(--font-body); font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0; }
.persona-benefits-actions { display: flex; gap: 30px; align-items: center; }

.stats-tall-section { background: var(--white); padding: 100px var(--page-padding); }
.stats-tall-section__container { max-width: var(--container); margin: 0 auto; display: flex; flex-direction: column; gap: 80px; align-items: center; }
.stats-tall-section__intro { display: flex; flex-direction: column; gap: 32px; align-items: center; justify-content: center; width: 1000px; max-width: 100%; }
.stats-tall-section__heading { font-family: var(--font-heading); font-weight: 700; font-size: 50px; line-height: normal; color: var(--dark); text-align: center; margin: 0; }
.stats-tall-section__desc { font-family: var(--font-body); font-size: var(--fs-t2); line-height: normal; color: var(--dark); text-align: center; margin: 0; }
.stats-tall-row { display: flex; gap: 32px; width: 100%; }
.stat-tall-card { flex: 1 0 0; min-width: 0; background: #dde8dd; border-radius: var(--radius-md); padding: 32px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; text-align: center; min-height: 212px; }
.stat-tall-card__value { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h0); line-height: normal; color: var(--dark); margin: 0; }
.stat-tall-card__label { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h5); line-height: normal; color: var(--dark); margin: 0; }
.stat-tall-card__desc { font-family: var(--font-body); font-size: var(--fs-t2); line-height: normal; color: var(--dark); text-align: center; margin: 8px 0 0; }

.practice-section { background: var(--white); padding: 100px var(--page-padding); }
.practice-section__container { max-width: var(--container); margin: 0 auto; display: flex; flex-direction: column; gap: 120px; align-items: center; }
.practice-section__intro { width: 1000px; max-width: 100%; display: flex; flex-direction: column; gap: 32px; align-items: center; }
.practice-section__title-block { display: flex; flex-direction: column; gap: 16px; align-items: center; width: 100%; }
.practice-section__title-content { display: flex; flex-direction: column; gap: 24px; align-items: center; text-align: center; width: 100%; }
.practice-section__heading { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h1); line-height: normal; color: var(--dark); margin: 0; }
.practice-section__desc { font-family: var(--font-body); font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0; }
.practice-section__actions { display: flex; gap: 30px; align-items: center; }
.practice-rows { display: flex; flex-direction: column; gap: 100px; width: 1000px; max-width: 100%; }
.practice-row { display: flex; flex-direction: column; gap: 60px; }
.practice-row__text { display: flex; flex-direction: column; gap: 24px; align-items: center; width: 100%; }
.practice-row__heading { font-family: var(--font-heading); font-weight: 700; font-size: 50px; line-height: normal; color: var(--green); text-transform: uppercase; text-align: left; margin: 0; width: 100%; }
.practice-row--right .practice-row__heading { text-align: right; }
.practice-row__desc { font-family: var(--font-body); font-size: var(--fs-t2); line-height: normal; color: var(--dark); text-align: center; margin: 0; width: 100%; }
.practice-row__image { width: 100%; height: 392px; border-radius: var(--radius-lg); overflow: hidden; }
.practice-row__image img { width: 100%; height: 100%; object-fit: cover; display: block; }

.testimonial-split--reverse { flex-direction: row-reverse; }
.testimonial-split-section--white { background: var(--white); }

/* Layout/485 — Numbered horizontal split (Dyrektor Produkcji "Korzyści") */
.role-progress-section { background: var(--gray-bg); padding: 100px var(--page-padding); }
.role-progress-section__container { max-width: var(--container); margin: 0 auto; display: flex; flex-direction: column; gap: 112px; }
.role-progress-row { display: flex; gap: 80px; align-items: flex-start; width: 100%; }
.role-progress-row__num { font-family: var(--font-heading); font-weight: 800; font-size: 200px; line-height: 1.3; color: var(--green); width: 224px; flex-shrink: 0; margin: 0; padding-top: 71.5px; text-align: center; }
.role-progress-row__content { flex: 1 0 0; min-width: 0; display: flex; flex-direction: column; }
.role-progress-row__bar { width: 100%; height: 2px; background: rgba(7,3,9,0.15); position: relative; }
.role-progress-row__bar::after { content: ""; position: absolute; left: 0; top: 0; width: 32px; height: 100%; background: var(--green); }
.role-progress-row__inner { padding-top: 32px; display: flex; flex-direction: column; gap: 32px; }
.role-progress-row__title-block { display: flex; flex-direction: column; gap: 16px; }
.role-progress-row__heading { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h1); line-height: normal; color: var(--dark); margin: 0; }
.role-progress-row__text { font-family: var(--font-body); font-size: var(--fs-t2); line-height: 1.35; color: var(--dark); margin: 0; }
.role-progress-row__buttons { display: flex; gap: 30px; align-items: center; }

/* Layout/65 — Split tagline+heading left + text+list+buttons right (Dyrektor Produkcji "Przepływ") */
.role-flow-section { background: var(--white); padding: 100px var(--page-padding); }
.role-flow-section__container { max-width: var(--container); margin: 0 auto; display: flex; gap: 80px; align-items: flex-start; }
.role-flow__left { flex: 1 0 0; min-width: 0; display: flex; flex-direction: column; gap: 16px; }
.role-flow__heading { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h1); line-height: normal; color: var(--dark); margin: 0; }
.role-flow__right { flex: 1 0 0; min-width: 0; display: flex; flex-direction: column; gap: 60px; }
.role-flow__text { font-family: var(--font-body); font-size: var(--fs-t2); line-height: 1.35; color: var(--dark); margin: 0; }
.role-flow__list { display: flex; flex-direction: column; gap: 16px; padding: 0; margin: 0; list-style: none; }
.role-flow__list-item { display: flex; gap: 16px; align-items: center; font-family: var(--font-body); font-size: var(--fs-t2); line-height: normal; color: var(--dark); }
.role-flow__list-icon { width: 24px; height: 24px; flex-shrink: 0; color: var(--green); }
.role-flow__list-icon svg { width: 100%; height: 100%; }
.role-flow__buttons { display: flex; gap: 30px; align-items: center; }

@media (max-width: 900px) {
  .role-progress-section, .role-flow-section { padding: 60px 24px; }
  .role-progress-section__container { gap: 60px; }
  .role-progress-row { flex-direction: column; gap: 24px; }
  .role-progress-row__num { width: auto; padding-top: 0; font-size: 100px; text-align: left; }
  .role-progress-row__heading { font-size: 36px; }
  .role-flow-section__container { flex-direction: column; gap: 40px; }
  .role-flow__heading { font-size: 36px; }
}

@media (max-width: 900px) {
  .persona-challenges-section, .persona-tools-section, .persona-benefits-section, .stats-tall-section, .practice-section { padding: 60px 24px; }
  .persona-challenges-section__heading, .persona-tools-section__heading, .persona-benefits-section__heading, .practice-section__heading { font-size: 40px; }
  .stats-tall-section__heading { font-size: 32px; }
  .green-cards-row { flex-direction: column; height: auto; gap: 24px; }
  .green-card, .green-card--wide { width: 100%; min-height: 320px; }
  .green-card--wide .green-card__title { font-size: 32px; }
  .persona-tools-row { flex-direction: column; gap: 32px; }
  .persona-tool-col__title { font-size: 28px; }
  .benefit-image-row { flex-direction: column; height: auto; gap: 24px; }
  .benefit-image-card { width: 100%; }
  .stats-tall-row { flex-direction: column; gap: 16px; }
  .stat-tall-card__value { font-size: 56px; }
  .practice-row__heading { font-size: 32px; }
  .practice-row__image { height: 240px; }
  .practice-section__container { gap: 60px; }
  .practice-rows { gap: 60px; }
}

/* ============================================================
   Polityka prywatności (Figma 25:11916)
   ============================================================ */

.privacy-header {
  background: var(--gray-bg);
  padding: 112px var(--page-padding);
}
.privacy-header__container { max-width: var(--container); margin: 0 auto; display: flex; flex-direction: column; align-items: center; }
.privacy-header__component { max-width: 768px; width: 100%; display: flex; flex-direction: column; gap: 32px; align-items: center; }
.privacy-header__title-block { display: flex; flex-direction: column; gap: 16px; align-items: center; width: 100%; }
.privacy-header__content { display: flex; flex-direction: column; gap: 24px; align-items: center; text-align: center; width: 100%; }
.privacy-header__heading { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h0); line-height: normal; color: var(--dark); margin: 0; }
.privacy-header__sub { font-family: var(--font-body); font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0; }

.privacy-content { background: var(--white); padding: 112px var(--page-padding); }
.privacy-content__container { max-width: var(--container); margin: 0 auto; display: flex; flex-direction: column; align-items: center; }
.privacy-content__inner { max-width: 768px; width: 100%; display: flex; flex-direction: column; gap: 64px; }
.privacy-content__heading { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h1); line-height: normal; color: var(--dark); margin: 0; }
.privacy-content__rich { font-family: var(--font-body); font-size: var(--fs-t2); line-height: 1.4; color: var(--dark); }
.privacy-content__rich > ol { display: flex; flex-direction: column; gap: 32px; padding-left: 30px; margin: 0; }
.privacy-content__rich > ol > li { padding-left: 8px; }
.privacy-content__rich > ol > li::marker { font-family: var(--font-heading); font-weight: 700; }
.privacy-content__rich h3 { font-family: var(--font-heading); font-weight: 700; font-size: var(--fs-h5); line-height: normal; color: var(--dark); margin: 0 0 12px; }
.privacy-content__rich p { margin: 0; }
.privacy-content__rich p + p { margin-top: 12px; }
.privacy-content__rich ul { margin: 12px 0 0; padding-left: 24px; display: flex; flex-direction: column; gap: 8px; }
.privacy-content__rich a { color: var(--green); text-decoration: underline; }
.privacy-content__rich a:hover { opacity: 0.85; }
.privacy-content__rich strong { font-weight: 700; }

@media (max-width: 900px) {
  .privacy-header { padding: 60px 24px; }
  .privacy-header__heading { font-size: 40px; }
  .privacy-content { padding: 60px 24px; }
  .privacy-content__heading { font-size: 36px; }
  .privacy-content__inner { gap: 32px; }
  .privacy-content__rich > ol { gap: 24px; padding-left: 24px; }
  .privacy-content__rich h3 { font-size: 22px; }
}

/* ============================================================
   Produkt: G-SENSE Predict (Figma 25:13916)
   ============================================================ */

/* Layout/1 — 2-col text + image */
.hero-2col-section {
  background: var(--white);
  padding: 100px var(--page-padding);
}
.hero-2col-section__container { max-width: var(--container); margin: 0 auto; }
.hero-2col { display: flex; gap: 80px; height: 640px; align-items: center; width: 100%; }
.hero-2col__text { flex: 1 0 0; min-width: 0; display: flex; flex-direction: column; gap: 32px; }
.hero-2col__title-block { display: flex; flex-direction: column; gap: 16px; }
.hero-2col__content { display: flex; flex-direction: column; gap: 24px; }
.hero-2col__heading { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h1); line-height: normal; color: var(--dark); margin: 0; }
.hero-2col__desc { font-family: var(--font-body); font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0; }
.hero-2col__actions { display: flex; gap: 30px; align-items: center; }
.hero-2col__image { flex: 1 0 0; min-width: 0; aspect-ratio: 600/640; border-radius: var(--radius-lg); overflow: hidden; }
.hero-2col__image img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Layout/399 — 4 dark gray cards with big numbers */
.process-cards-section { background: var(--white); padding: 100px var(--page-padding); }
.process-cards-section__container { max-width: var(--container); margin: 0 auto; display: flex; flex-direction: column; gap: 80px; align-items: center; }
.process-cards-section__title { max-width: 768px; width: 100%; display: flex; flex-direction: column; gap: 16px; align-items: center; text-align: center; }
.process-cards-section__title-content { display: flex; flex-direction: column; gap: 24px; align-items: center; width: 100%; }
.process-cards-section__heading { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h1); line-height: normal; color: var(--dark); margin: 0; }
.process-cards-section__desc { font-family: var(--font-body); font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0; }
.process-cards-row { display: flex; gap: 24px; width: 100%; }
.process-card { flex: 1 0 0; min-width: 0; height: 550px; background: var(--gray-mid2); border-radius: var(--radius-md); padding: 32px 24px; display: flex; flex-direction: column; justify-content: space-between; color: var(--white); overflow: hidden; box-sizing: border-box; }
.process-card__top { display: flex; flex-direction: column; gap: 32px; }
.process-card__num { font-family: var(--font-heading); font-weight: 800; font-size: 100px; line-height: 1; color: var(--white); margin: 0; }
.process-card__content { display: flex; flex-direction: column; gap: 16px; }
.process-card__title { font-family: var(--font-heading); font-weight: 700; font-size: var(--fs-h3-5); line-height: normal; color: var(--white); margin: 0; }
.process-card__desc { font-family: var(--font-body); font-size: var(--fs-t2); line-height: normal; color: var(--white); margin: 0; }
.process-card__link { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-body); font-weight: 700; font-size: 18px; color: var(--white); text-decoration: none; }
.process-card__link svg { width: 24px; height: 24px; }

/* Layout/396 — 3 columns: centered icon + heading + text + button (G-SENSE MES — Metryki) */
.metric-cards-section { background: var(--white); padding: 100px var(--page-padding); }
.metric-cards-section__container { max-width: var(--container); margin: 0 auto; display: flex; flex-direction: column; gap: 80px; align-items: center; }
.metric-cards-section__title { max-width: 768px; width: 100%; display: flex; flex-direction: column; gap: 16px; align-items: center; text-align: center; }
.metric-cards-section__title-content { display: flex; flex-direction: column; gap: 24px; align-items: center; width: 100%; }
.metric-cards-section__heading { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h1); line-height: normal; color: var(--dark); margin: 0; }
.metric-cards-section__desc { font-family: var(--font-body); font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0; }
.metric-cards-row { display: flex; gap: 32px; width: 100%; }
.metric-card { flex: 1 0 0; min-width: 0; height: 420px; background: var(--white); border-radius: var(--radius-md); padding: 32px; display: flex; flex-direction: column; justify-content: space-between; box-sizing: border-box; border: 1px solid var(--border); }
.metric-card__top { display: flex; flex-direction: column; align-items: center; gap: 32px; text-align: center; }
.metric-card__icon { width: 48px; height: 48px; color: var(--green); }
.metric-card__icon svg { width: 100%; height: 100%; }
.metric-card__content { display: flex; flex-direction: column; gap: 8px; width: 100%; }
.metric-card__title { font-family: var(--font-heading); font-weight: 700; font-size: var(--fs-h3); line-height: normal; color: var(--dark); margin: 0; }
.metric-card__desc { font-family: var(--font-body); font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0; }
.metric-card__actions { display: flex; justify-content: center; }

/* Layout/220 — 2x2 grid of white cards with green border */
.benefits-2x2-section { background: var(--gray-bg); padding: 100px var(--page-padding); }
.benefits-2x2-section__container { max-width: var(--container); margin: 0 auto; display: flex; flex-direction: column; gap: 80px; align-items: center; }
.benefits-2x2-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; width: 100%; }
.benefits-2x2-grid .benefit-card { background: var(--white); border: 1px solid var(--green); border-radius: var(--radius-md); padding: 24px; display: flex; flex-direction: column; align-items: flex-start; text-align: left; gap: 16px; min-height: 224px; box-sizing: border-box; color: var(--dark); flex: initial; width: auto; }
.benefits-2x2-grid .benefit-card__icon { width: 48px; height: 48px; flex-shrink: 0; color: var(--green); display: flex; align-items: center; justify-content: center; }
.benefits-2x2-grid .benefit-card__icon svg, .benefits-2x2-grid .benefit-card__icon img { width: 100%; height: 100%; object-fit: contain; display: block; }
.benefits-2x2-grid .benefit-card__title { font-family: var(--font-heading); font-weight: 700; font-size: var(--fs-h3-5); line-height: normal; color: var(--dark); margin: 0; text-align: left; }
.benefits-2x2-grid .benefit-card__desc { font-family: var(--font-body); font-weight: 400; font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0; text-align: left; }
.benefits-2x2-actions { display: flex; gap: 24px; align-items: center; }
.btn--neutral { background: #b4b3b5; color: var(--white); }

/* Layout/400 — 4 green cards with icon + tag + heading */
.sectors-cards-section { background: var(--white); padding: 100px var(--page-padding); }
.sectors-cards-section__container { max-width: var(--container); margin: 0 auto; display: flex; flex-direction: column; gap: 80px; align-items: center; }
.sectors-cards-section__title { max-width: 768px; width: 100%; display: flex; flex-direction: column; gap: 16px; align-items: center; text-align: center; }
.sectors-cards-section__title-content { display: flex; flex-direction: column; gap: 24px; align-items: center; width: 100%; }
.sectors-cards-section__heading { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h1); line-height: normal; color: var(--dark); margin: 0; }
.sectors-cards-section__desc { font-family: var(--font-body); font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0; }
.sectors-cards-row { display: flex; gap: 26.67px; width: 100%; justify-content: space-between; }
.sector-card { width: 300px; height: 520px; background: var(--green); border-radius: var(--radius-md); padding: 24px; display: flex; flex-direction: column; justify-content: space-between; color: var(--white); overflow: hidden; box-sizing: border-box; }
.sector-card__top { display: flex; flex-direction: column; gap: 32px; }
.sector-card__head { display: flex; flex-direction: column; gap: 24px; align-items: flex-start; }
.sector-card__icon { width: 72px; height: 72px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; color: var(--white); }
.sector-card__icon img, .sector-card__icon svg { width: 100%; height: 100%; object-fit: contain; }
.sector-card__tag { display: inline-flex; background: var(--white); color: var(--green); padding: 4px 10px; border-radius: var(--radius-petite); font-family: var(--font-body); font-weight: 600; font-size: 16px; line-height: 1.5; }
.sector-card__title { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h3-5); line-height: normal; color: var(--white); margin: 0; }
.sector-card__desc { font-family: var(--font-body); font-size: var(--fs-t2); line-height: normal; color: var(--white); margin: 0; }
.sector-card__link { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-body); font-weight: 700; font-size: 18px; color: var(--white); text-decoration: none; }
.sector-card__link svg { width: 24px; height: 24px; }

/* Pricing/19 — 3 columns light green */
.pricing-section { background: var(--white); padding: 100px var(--page-padding); }
.pricing-section__container { max-width: var(--container); margin: 0 auto; display: flex; flex-direction: column; gap: 80px; align-items: center; }
.pricing-section__title { max-width: 768px; width: 100%; display: flex; flex-direction: column; gap: 16px; align-items: center; text-align: center; }
.pricing-section__title-content { display: flex; flex-direction: column; gap: 24px; align-items: center; width: 100%; }
.pricing-section__heading { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h0); line-height: normal; color: var(--dark); margin: 0; }
.pricing-section__desc { font-family: var(--font-body); font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0; }
.pricing-row { display: flex; gap: 32px; width: 100%; height: 550px; }
.pricing-col { flex: 1 0 0; min-width: 0; background: #dde8dd; border-radius: var(--radius-md); padding: 32px; display: flex; flex-direction: column; justify-content: space-between; box-sizing: border-box; }
.pricing-col__top { display: flex; flex-direction: column; gap: 24px; }
.pricing-col__title { font-family: var(--font-heading); font-weight: 700; font-size: var(--fs-h3-5); line-height: normal; color: var(--dark); margin: 0; }
.pricing-col__value { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h0); line-height: normal; color: var(--dark); margin: 0; }
.pricing-col__unit { font-family: var(--font-body); font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0; }
.pricing-col__divider { width: 100%; height: 1px; background: var(--border); }
.pricing-col__list-head { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h5); line-height: normal; color: var(--dark); margin: 0; }
.pricing-col__list { display: flex; flex-direction: column; gap: 16px; list-style: none; padding: 0; margin: 0; }
.pricing-col__list li { display: flex; align-items: flex-start; gap: 16px; font-family: var(--font-body); font-size: var(--fs-t3); line-height: normal; color: var(--dark); }
.pricing-col__list li svg { width: 24px; height: 24px; flex-shrink: 0; color: var(--green); }

/* Testimonial/43 — split: left heading, right single card + slider arrows */
.testimonial-split-section { background: var(--gray-bg); padding: 100px var(--page-padding); }
.testimonial-split-section__container { max-width: var(--container); margin: 0 auto; }
.testimonial-split { display: flex; gap: 80px; align-items: flex-start; width: 100%; }
.testimonial-split__left { flex: 1 0 0; min-width: 0; align-self: stretch; display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; gap: 16px; }
.testimonial-split__heading { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h1); line-height: normal; color: var(--dark); margin: 0; }
.testimonial-split__desc { font-family: var(--font-body); font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0; }
.testimonial-split__right { width: 600px; display: flex; flex-direction: column; gap: 48px; }
.testimonial-card { background: var(--white); border: 1px solid #b4b3b5; border-radius: var(--radius-md); padding: 32px; display: flex; flex-direction: column; gap: 32px; }
.testimonial-card__body { display: flex; flex-direction: column; gap: 48px; }
.testimonial-card__logo { height: 48px; display: flex; align-items: center; }
.testimonial-card__logo img { max-height: 48px; width: auto; }
.testimonial-card__content { display: flex; flex-direction: column; gap: 24px; }
.testimonial-card__quote { font-family: var(--font-heading); font-weight: 600; font-size: var(--fs-h5); line-height: normal; color: var(--dark); margin: 0; }
.testimonial-card__avatar { display: flex; gap: 20px; align-items: center; }
.testimonial-card__avatar-img { width: 64px; height: 64px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.testimonial-card__avatar-text { display: flex; flex-direction: column; }
.testimonial-card__name { font-family: var(--font-body); font-weight: 600; font-size: var(--fs-t2); color: var(--dark); margin: 0; }
.testimonial-card__role { font-family: var(--font-body); font-size: var(--fs-t2); color: var(--dark); margin: 0; }
.testimonial-card__action { display: inline-flex; align-items: center; gap: 8px; padding: 4px 12px; border-radius: var(--radius-petite); font-family: var(--font-body); font-weight: 700; font-size: 18px; color: var(--dark); text-decoration: none; align-self: flex-start; }
.testimonial-card__action svg { width: 24px; height: 24px; }
.testimonial-slider-controls { display: flex; gap: 32px; align-items: center; justify-content: center; }
.testimonial-slider-arrow { background: var(--green); border: none; width: 48px; height: 48px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; cursor: pointer; color: var(--white); }
.testimonial-slider-arrow svg { width: 24px; height: 24px; }
.testimonial-slider-dots { display: flex; gap: 14px; }
.testimonial-slider-dot { width: 14px; height: 14px; border-radius: 50%; background: rgba(7,3,9,0.2); }
.testimonial-slider-dot.is-active { background: var(--green); }

/* CTA/51 — green card banner (large) */
.cta-card-section { background: var(--white); padding: 100px var(--page-padding); }
.cta-card-section__container { max-width: var(--container); margin: 0 auto; }
.cta-card-banner { background: var(--green); border-radius: var(--radius-lg); padding: 64px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 40px; min-height: 352px; text-align: center; }
.cta-card-banner__title { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h1); line-height: normal; color: var(--white); margin: 0; max-width: 1078px; }
.cta-card-banner__desc { font-family: var(--font-body); font-size: var(--fs-h5); line-height: 1.5; color: var(--white); margin: 0; max-width: 1078px; }

/* Responsive — G-SENSE Predict */
@media (max-width: 900px) {
  .hero-2col-section, .process-cards-section, .benefits-2x2-section, .sectors-cards-section, .pricing-section, .testimonial-split-section, .cta-card-section { padding: 60px 24px; }
  .hero-2col { flex-direction: column; height: auto; gap: 32px; }
  .hero-2col__image { width: 100%; aspect-ratio: 4/3; }
  .hero-2col__heading, .process-cards-section__heading, .sectors-cards-section__heading, .testimonial-split__heading { font-size: 40px; }
  .pricing-section__heading, .cta-card-banner__title { font-size: 40px; }
  .process-cards-row, .sectors-cards-row, .pricing-row { flex-direction: column; height: auto; gap: 24px; }
  .process-card, .pricing-col { height: auto; min-height: 360px; }
  .sector-card { width: 100%; height: auto; min-height: 400px; }
  .benefits-2x2-grid { grid-template-columns: 1fr; }
  .testimonial-split { flex-direction: column; }
  .testimonial-split__right { width: 100%; }
}

/* ============================================================
   Baza Wiedzy > Artykuł (Figma 25:12345)
   ============================================================ */

/* Blog Post Header — title + tag + cover image + author meta */
.blog-post-header {
  background: var(--white);
  padding: 100px var(--page-padding);
}
.blog-post-header__container {
  max-width: var(--container);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 80px;
}
.blog-post-header__top { display: flex; flex-direction: column; gap: 48px; }
.blog-post-header__back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  color: var(--dark);
  text-decoration: none;
  font-weight: 400;
  align-self: flex-start;
}
.blog-post-header__back:hover { color: var(--green); }
.blog-post-header__back svg { width: 24px; height: 24px; transform: rotate(180deg); }
.blog-post-header__heading { display: flex; flex-direction: column; gap: 16px; }
.blog-post-header__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h1);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.blog-post-header__cover {
  width: 100%;
  height: 600px;
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.blog-post-header__cover img { width: 100%; height: 100%; object-fit: cover; display: block; }
.blog-post-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}
.blog-post-meta__info { display: flex; gap: 48px; }
.blog-post-meta__col { display: flex; flex-direction: column; gap: 8px; }
.blog-post-meta__label {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  color: var(--dark);
  margin: 0;
}
.blog-post-meta__value {
  font-family: var(--font-body);
  font-weight: 600;
  font-size: var(--fs-h5);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.blog-post-meta__social { display: flex; gap: 12px; align-items: center; }
.blog-post-meta__social a {
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.blog-post-meta__social img { width: 100%; height: 100%; }

/* Article body: 2-col TOC sidebar + Rich text */
.article-section {
  background: var(--white);
  padding: 100px var(--page-padding);
}
.article-section__container {
  max-width: var(--container);
  margin: 0 auto;
  display: flex;
  gap: 192px;
  align-items: flex-start;
}
.toc-column {
  width: 320px;
  flex-shrink: 0;
  position: sticky;
  top: 100px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.toc-column__heading {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h3);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.toc-list { display: flex; flex-direction: column; list-style: none; padding: 0; margin: 0; }
.toc-link {
  display: block;
  padding: 16px;
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: normal;
  color: var(--dark);
  text-decoration: none;
  border-bottom: 1px solid var(--border);
}
.toc-link:first-child { border-top: 1px solid var(--border); }
.toc-link:hover { color: var(--green); }
.toc-link.is-active { color: var(--green); font-weight: 600; }
.article-rich-text {
  flex: 1;
  min-width: 0;
  max-width: 768px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.article-rich-text > * { margin: 0; }
.article-rich-text h1 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 50px;
  line-height: normal;
  color: var(--dark);
  margin: 8px 0 0;
}
.article-rich-text h2 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h3);
  line-height: normal;
  color: var(--dark);
  margin: 24px 0 0;
}
.article-rich-text h3 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h3-5);
  line-height: normal;
  color: var(--dark);
  margin: 24px 0 0;
}
.article-rich-text h4 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h5);
  line-height: normal;
  color: var(--dark);
  margin: 20px 0 0;
}
.article-rich-text h5 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h5);
  line-height: normal;
  color: var(--dark);
  margin: 20px 0 0;
}
.article-rich-text p {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--dark);
}
.article-rich-text ul, .article-rich-text ol {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--dark);
  padding-left: 24px;
}
.article-rich-text ul li, .article-rich-text ol li { margin-bottom: 8px; }
.article-rich-text blockquote {
  margin: 12px 0;
  padding: 16px 24px;
  border-left: 4px solid var(--green);
  background: var(--green-light);
  border-radius: 0 8px 8px 0;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: var(--fs-h5);
  font-style: italic;
  line-height: normal;
  color: var(--dark);
}
.article-rich-text blockquote p { font-size: inherit; font-weight: inherit; }
.article-rich-text figure {
  margin: 24px 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.article-rich-text figure img {
  width: 100%;
  border-radius: var(--radius-md);
  display: block;
}
.article-rich-text figcaption {
  padding: 0 8px;
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.5;
  color: var(--gray-text);
}

/* Newsletter CTA banner (CTA / 51 z formularzem) */
.newsletter-cta {
  background: var(--white);
  padding: 100px var(--page-padding);
}
.newsletter-cta__container { max-width: var(--container); margin: 0 auto; }
.newsletter-cta__card {
  background: var(--green);
  border-radius: var(--radius-lg);
  padding: 64px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 40px;
  text-align: center;
}
.newsletter-cta__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h0);
  line-height: normal;
  color: var(--white);
  margin: 0;
}
.newsletter-cta__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t3);
  line-height: 1.5;
  color: var(--white);
  margin: 0;
}
.newsletter-cta__form-wrap { display: flex; flex-direction: column; gap: 16px; align-items: center; }
.newsletter-cta__form-wrap .newsletter-form .btn--primary {
  background: var(--white);
  color: var(--dark);
}
.newsletter-cta__consent {
  font-family: var(--font-body);
  font-size: var(--fs-t4);
  line-height: 1.5;
  color: rgba(255,255,255,0.85);
}

/* Blog cards section "Czytaj dalej" */
.related-blog-section {
  background: var(--white);
  padding: 100px var(--page-padding);
}
.related-blog-section__container {
  max-width: var(--container);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 80px;
  align-items: center;
}
.related-blog-section__title {
  max-width: 768px;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: center;
  text-align: center;
}
.related-blog-section__title-content { display: flex; flex-direction: column; gap: 24px; align-items: center; width: 100%; }
.related-blog-section__heading {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h1);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.related-blog-section__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.related-blog-row {
  display: flex;
  gap: 40px;
  width: 100%;
  justify-content: space-between;
}
.related-blog-row .blog-card { flex: 1 0 0; min-width: 0; height: auto; }

/* Responsive — artykuł */
@media (max-width: 900px) {
  .blog-post-header { padding: 60px 24px; }
  .blog-post-header__cover { height: 280px; }
  .blog-post-header__title { font-size: 36px; }
  .blog-post-meta { flex-direction: column; gap: 16px; align-items: flex-start; }
  .article-section { padding: 60px 24px; }
  .article-section__container { flex-direction: column; gap: 40px; }
  .toc-column { position: static; width: 100%; }
  .article-rich-text h1 { font-size: 32px; }
  .article-rich-text h2 { font-size: 28px; }
  .newsletter-cta { padding: 60px 24px; }
  .newsletter-cta__card { padding: 32px 20px; }
  .newsletter-cta__title { font-size: 32px; }
  .related-blog-section { padding: 60px 24px; }
  .related-blog-row { flex-direction: column; gap: 24px; }
}

/* ============================================================
   Sektor: Sieci sklepów i stacje paliw (Figma 25:9564)
   ============================================================ */

/* Dark button (Hero "Audyt") */
.btn--dark { background: var(--dark); color: var(--white); }

/* Layout/520 — Challenges: 3 stacked horizontal cards z border-left */
.challenges-section {
  background: var(--gray-bg);
  padding: 100px var(--page-padding);
}
.challenges-section__container {
  max-width: var(--container);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 80px;
  align-items: center;
}
.challenges-section__title {
  max-width: 768px;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: center;
  text-align: center;
}
.challenges-section__title-content {
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: center;
  width: 100%;
}
.challenges-section__heading {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h1);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.challenges-section__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.challenges-row {
  display: flex;
  flex-direction: column;
  gap: 32px;
  width: 100%;
}
.challenge-card {
  background: var(--green-light);
  border-left: 8px solid var(--green);
  border-radius: var(--radius-md);
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: 100%;
  box-sizing: border-box;
}
.challenge-card--with-action {
  flex-direction: row;
  gap: 32px;
  align-items: flex-end;
}
.challenge-card__content {
  flex: 1 0 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.challenge-card__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h3);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.challenge-card__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}

/* Timeline variant: text on the LEFT (right-aligned), bullet on the RIGHT */
.timeline--right .timeline-item {
  flex-direction: row;
}
.timeline--right .timeline-item__content {
  text-align: right;
  align-items: flex-end;
}

/* Layout/423 — Tech cards (3 kolumny z tagiem + border zielony, jedna z tłem) */
.tech-cards-row {
  display: flex;
  gap: 40px;
  width: 100%;
  justify-content: space-between;
  align-items: stretch;
}
.tech-card {
  flex: 1 0 0;
  min-width: 0;
  height: 500px;
  border: 4px solid var(--green);
  border-radius: var(--radius-lg);
  background: var(--white);
  padding: 32px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  overflow: hidden;
  box-sizing: border-box;
}
.tech-card--image {
  border: none;
  color: var(--white);
}
.tech-card--image::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--bg);
  background-size: cover;
  background-position: center;
  z-index: 0;
}
.tech-card--image::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  z-index: 0;
}
.tech-card--image > * { position: relative; z-index: 1; }
.tech-card__top { display: flex; flex-direction: column; gap: 16px; }
.tech-card__body { display: flex; flex-direction: column; gap: 24px; }
.tech-card__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h3);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.tech-card--image .tech-card__title { color: var(--white); }
.tech-card__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.tech-card--image .tech-card__desc { color: var(--white); }
.tech-card__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 18px;
  color: var(--dark);
  text-decoration: none;
}
.tech-card--image .tech-card__link { color: var(--white); }
.tech-card__link:hover { opacity: 0.85; }
.tech-card__link svg { width: 24px; height: 24px; }

/* Layout/373 — Results cards: asymmetric 1fr / 640px / 1fr, dark gray */
.results-section {
  background: var(--white);
  padding: 100px var(--page-padding);
}
.results-section__container {
  max-width: var(--container);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 80px;
  align-items: center;
}
.results-section__title {
  max-width: 768px;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: center;
  text-align: center;
}
.results-section__title-content { display: flex; flex-direction: column; gap: 24px; align-items: center; width: 100%; }
.results-section__heading {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h1);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.results-section__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.results-row {
  display: flex;
  gap: 32px;
  width: 100%;
  height: 400px;
}
.result-card {
  flex: 1 0 0;
  min-width: 0;
  background: var(--gray-mid2);
  border-radius: var(--radius-md);
  padding: 24px 16px;
  display: flex;
  flex-direction: column;
  color: var(--white);
  overflow: hidden;
}
.result-card__inner {
  flex: 1;
  padding: 0 16px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 0;
}
.result-card--wide {
  flex: none;
  width: 640px;
  padding: 24px 32px;
}
.result-card--wide .result-card__inner { padding: 0; }
.result-card__top { display: flex; flex-direction: column; gap: 16px; }
.result-card--wide .result-card__top { gap: 24px; }
.result-card__icon { width: 48px; height: 48px; flex-shrink: 0; }
.result-card__icon img { width: 100%; height: 100%; display: block; }
.result-card__content { display: flex; flex-direction: column; gap: 12px; }
.result-card--wide .result-card__content { gap: 16px; }
.result-card__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h3-5);
  line-height: normal;
  color: var(--white);
  margin: 0;
}
.result-card--wide .result-card__title { font-size: 50px; }
.result-card__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t3);
  line-height: normal;
  color: var(--white);
  margin: 0;
}
.result-card--wide .result-card__desc { font-size: var(--fs-t2); }
.result-card__actions {
  display: flex;
  gap: 30px;
  align-items: center;
}

/* Responsive */
@media (max-width: 900px) {
  .challenges-section, .results-section { padding: 60px 24px; }
  .challenge-card--with-action { flex-direction: column; align-items: flex-start; }
  .challenge-card__title { font-size: 28px; }
  .challenges-section__heading, .results-section__heading { font-size: 40px; }
  .tech-cards-row { flex-direction: column; gap: 24px; }
  .tech-card { width: 100%; height: auto; min-height: 400px; }
  .results-row { flex-direction: column; height: auto; gap: 24px; }
  .result-card, .result-card--wide { width: 100%; min-height: 320px; }
  .result-card--wide .result-card__title { font-size: 36px; }
}


/* ========================================
   SECTORS — Kopalnie additions (light variant + hero dark glass btn)
   Reuses .challenges-section, .tech-cards-row/.tech-card,
   .results-section/.results-row/.result-card from sibling sektor pages.
   ======================================== */

/* Dark transparent button — hero CTA "Prezentacja" */
.btn--glass-dark { background: rgba(7,3,9,0.6); color: var(--white); }

/* Wskaźniki section — horizontal row of action buttons next to heading */
.timeline-section__actions {
  display: flex;
  gap: 30px;
  align-items: center;
}

/* Light variant of results section (gray bg + white cards w/ dark text) */
.results-section--gray { background: var(--gray-bg); }
.result-card--light { background: var(--white); color: var(--dark); }
.result-card--light .result-card__title,
.result-card--light .result-card__desc { color: var(--dark); }

/* Tech card height override for kopalnie Figma frame (427px instead of default 500) */
.tech-cards-row--compact .tech-card { height: 427px; }

/* Layout/121 wariant: tytuł + CTA po PRAWEJ stronie (Sektory > Przemysł) */
.timeline-section__right {
  display: flex;
  flex-direction: column;
  gap: 32px;
  align-items: flex-start;
}
.timeline-section__right .btn { gap: 8px; }

/* Layout/396 — Outcome cards: 3 białe karty z ikoną na górze */
.outcome-cards {
  display: flex;
  gap: 32px;
  width: 100%;
  align-items: stretch;
}
.outcome-card {
  flex: 1 0 0;
  min-width: 0;
  background: var(--white);
  border-radius: var(--radius-md);
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 24px;
  justify-content: center;
  min-height: 450px;
}
.outcome-card__icon { width: 48px; height: 48px; flex-shrink: 0; }
.outcome-card__content {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.outcome-card__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h3);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.outcome-card__desc {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: var(--fs-t2);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}

@media (max-width: 1100px) {
  .problem-card { flex-direction: column; align-items: flex-start; }
  .tool-cards { grid-template-columns: 1fr; }
  .result-cards { grid-template-columns: 1fr; }
  .outcome-cards { flex-direction: column; }
  .tech-cards-row { flex-direction: column; }
  .tech-card { width: 100%; height: auto; min-height: 400px; }
  .timeline-section__container { flex-direction: column; }
  .challenges-row { gap: 16px; }
}

/* ============================================================
   BAZA WIEDZY > Biblioteka Case Studies (Figma 25:10481)
   ============================================================ */

/* Blog/30 — Section wrapper: section title + filter bar + 4 cards + Load more */
.case-library {
  background: var(--white);
  padding: var(--padding-section-lg) var(--page-padding);
  display: flex;
  flex-direction: column;
  gap: 80px;
  align-items: center;
}
.case-library__container {
  max-width: var(--container);
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 80px;
  align-items: center;
}
.case-library__title {
  max-width: 768px;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: center;
  text-align: center;
}
.case-library__title-content {
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: center;
  width: 100%;
}
.case-library__heading {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h0);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.case-library__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}

/* Filter bar — "Wszystkie" dropdown + "Filtruj" button + active tag pills */
.case-filter {
  width: 768px;
  max-width: 100%;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.case-filter__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
}
.btn--filter-active {
  background: #dde8dd;
  color: var(--dark);
  border: 1px solid var(--green);
  gap: 8px;
}
.btn--filter-active svg { transform: rotate(90deg); }
.case-filter__tags {
  display: flex;
  gap: 20px;
  align-items: center;
  width: 100%;
  justify-content: flex-end;
}

/* Row of 4 case cards (304x512 dark image cards) */
.case-cards-row {
  display: flex;
  gap: 32px;
  width: 100%;
  align-items: stretch;
}
.case-card {
  flex: 1 0 0;
  min-width: 0;
  height: 512px;
  position: relative;
  border-radius: var(--radius-md);
  padding: 24px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  color: var(--white);
  isolation: isolate;
}
.case-card__bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  border-radius: var(--radius-md);
}
.case-card__bg img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.case-card__overlay {
  position: absolute;
  inset: 0;
  z-index: -1;
  background: rgba(0, 0, 0, 0.7);
  border-radius: var(--radius-md);
}
.case-card__top {
  display: flex;
  flex-direction: column;
  gap: 12px;
  width: 100%;
}
.case-card__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h3-5);
  line-height: normal;
  color: var(--white);
  margin: 0;
}
.case-card__desc {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: var(--fs-t2);
  line-height: normal;
  color: var(--white);
  margin: 0;
}
.case-card__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 18px;
  color: var(--white);
  text-decoration: none;
  align-self: flex-start;
}
.case-card__link svg { width: 24px; height: 24px; }
.case-card__link:hover { opacity: 0.85; }

/* Testimonial/23 — slider with 3 cards 350x480 + arrows + dots */
.testimonials-slider-section {
  background: var(--gray-bg);
  padding: var(--padding-section-lg) var(--page-padding);
}
.testimonials-slider-section__container {
  max-width: var(--container);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 80px;
  align-items: center;
}
.testimonials-slider-section__title {
  max-width: 768px;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: center;
  text-align: center;
}
.testimonials-slider-section__heading {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h1);
  line-height: normal;
  color: var(--dark);
  margin: 0;
  width: 560px;
  max-width: 100%;
}
.testimonials-slider-section__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: normal;
  color: var(--dark);
  margin: 0;
  width: 560px;
  max-width: 100%;
}
.testimonials-slider {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 48px;
  align-items: center;
}
.testimonials-slider__track {
  display: flex;
  gap: 32px;
  align-items: center;
  width: 100%;
}
.slider-arrow {
  background: var(--green);
  color: var(--white);
  width: 48px;
  height: 48px;
  border-radius: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  border: none;
  cursor: pointer;
  transition: opacity 0.2s;
}
.slider-arrow:hover { opacity: 0.85; }
.slider-arrow svg { width: 24px; height: 24px; }
.testimonial-slide {
  flex: 1 0 0;
  min-width: 0;
  width: 350px;
  max-width: 350px;
  height: 480px;
  background: var(--white);
  border-radius: var(--radius-md);
  padding: 32px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 32px;
}
.testimonial-slide__content {
  display: flex;
  flex-direction: column;
  gap: 48px;
}
.testimonial-slide__logo {
  height: 48px;
  display: flex;
  align-items: center;
}
.testimonial-slide__logo img { height: 48px; width: auto; }
.testimonial-slide__body {
  display: flex;
  flex-direction: column;
  gap: 32px;
}
.testimonial-slide__avatar {
  display: flex;
  gap: 20px;
  align-items: flex-start;
}
.testimonial-slide__avatar-img {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}
.testimonial-slide__avatar-text {
  flex: 1 0 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  font-size: var(--fs-t2);
}
.testimonial-slide__name {
  font-family: var(--font-body);
  font-weight: 600;
  color: var(--dark);
}
.testimonial-slide__role {
  font-family: var(--font-body);
  font-weight: 400;
  color: var(--dark);
}
.testimonial-slide__quote {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: var(--fs-t2);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.testimonial-slide__cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 18px;
  color: var(--dark);
  text-decoration: none;
  align-self: flex-start;
}
.testimonial-slide__cta svg { width: 24px; height: 24px; }
.testimonial-slide__cta:hover { opacity: 0.85; }
.slider-dots {
  display: flex;
  gap: 14px;
  align-items: center;
}
.slider-dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: rgba(7, 3, 9, 0.2);
  border: none;
  padding: 0;
  cursor: pointer;
  transition: background 0.2s;
}
.slider-dot--active { background: var(--green); }
.slider-dot:hover { background: var(--green); }

/* CTA banner with 2 buttons centered */
.cta-banner__actions {
  display: flex;
  gap: 16px;
  justify-content: center;
}

/* Header / 64 — prosty page header (Kalkulator, Audyt itp.) */
.page-header {
  padding: 112px var(--page-padding) 100px;
  background: var(--white);
  margin-top: 80px;
}
.page-header__content {
  max-width: 768px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: center;
  text-align: center;
}
.page-header__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h0);
  line-height: 1.05;
  color: var(--dark);
  margin: 0;
}
.page-header__desc {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--dark);
  margin: 0;
}

/* CTA / 33 — sekcja z headingiem, 2 buttonami i logo carousel pod spodem */
.cta-actions {
  display: flex;
  gap: 16px;
  justify-content: center;
  margin-top: 32px;
}

/* CTA / 51 — wariant cta-banner z formą newsletter (zielony banner z białym przyciskiem) */
.cta-banner--newsletter {
  gap: 32px;
}
.cta-banner__newsletter {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.cta-banner__newsletter .newsletter-form__input {
  background: var(--white);
}
.cta-banner__consent {
  display: block;
  font-size: 12px;
  color: rgba(255,255,255,0.85);
  text-align: center;
}

@media (max-width: 1100px) {
  .case-cards-row { flex-wrap: wrap; }
  .case-card { flex: 1 0 calc(50% - 16px); }
  .testimonials-slider__track { flex-wrap: wrap; justify-content: center; }
  .testimonial-slide { width: 100%; max-width: 350px; }
  .page-header__title { font-size: 64px; }
  .calc-header { flex-direction: column; gap: 24px; }
  .calc-actions { flex-direction: column; }
}
@media (max-width: 768px) {
  .case-library__heading { font-size: 48px; }
  .case-filter { width: 100%; }
  .case-cards-row { flex-direction: column; }
  .case-card { width: 100%; flex: none; height: auto; min-height: 360px; }
  .testimonials-slider-section__heading { font-size: 36px; }
}

/* ============================================================
   PRODUKT: Panoramic Power (Figma 25:13066)
   ============================================================ */

/* Layout/400 — 4 GREEN step cards with big number */
.step-cards-row { display: flex; gap: 24px; width: 100%; height: 460px; }
.step-card {
  flex: 1 0 0; min-width: 0;
  background: var(--green);
  border-radius: var(--radius-md);
  padding: 32px 24px;
  color: var(--white);
  display: flex; flex-direction: column; gap: 32px;
  overflow: hidden;
}
.step-card__num {
  font-family: var(--font-heading); font-weight: 800;
  font-size: 100px; line-height: 1; color: var(--white); margin: 0;
}
.step-card__content { display: flex; flex-direction: column; gap: 16px; }
.step-card__title {
  font-family: var(--font-heading); font-weight: 700;
  font-size: var(--fs-h3-5); line-height: normal; color: var(--white); margin: 0;
}
.step-card__text {
  font-family: var(--font-body);
  font-size: var(--fs-t2); line-height: normal; color: var(--white); margin: 0;
}

/* Layout/145 — Centered icon + tagline + heading + buttons + big image */
.icon-banner-section { background: var(--white); padding: 100px var(--page-padding); }
.icon-banner-section__container {
  max-width: var(--container); margin: 0 auto;
  display: flex; flex-direction: column; gap: 80px; align-items: center;
}
.icon-banner-section__head {
  max-width: 768px; width: 100%;
  display: flex; flex-direction: column; gap: 32px; align-items: center; text-align: center;
}
.icon-banner-section__icon { width: 80px; height: 80px; }
.icon-banner-section__icon img { width: 100%; height: 100%; }
.icon-banner-section__title-block {
  display: flex; flex-direction: column; gap: 16px; align-items: center; width: 100%;
}
.icon-banner-section__title-content {
  display: flex; flex-direction: column; gap: 24px; align-items: center; width: 100%;
}
.icon-banner-section__heading {
  font-family: var(--font-heading); font-weight: 800;
  font-size: var(--fs-h1); line-height: normal; color: var(--dark); margin: 0;
}
.icon-banner-section__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0;
}
.icon-banner-section__actions { display: flex; gap: 30px; align-items: center; }
.icon-banner-section__image {
  width: 100%; aspect-ratio: 1280/738;
  border-radius: var(--radius-lg); overflow: hidden;
}
.icon-banner-section__image img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Layout/220 — 2x2 grid of bordered white cards (Panoramic Power "Jakie dane zbiera system?") */
.data-cards-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; width: 100%; }
.data-card {
  background: var(--white); border: 1px solid var(--green);
  border-radius: var(--radius-md); padding: 24px;
  display: flex; flex-direction: column; gap: 16px;
  min-height: 224px; box-sizing: border-box;
}
.data-card__icon { width: 48px; height: 48px; flex-shrink: 0; }
.data-card__icon img { width: 100%; height: 100%; display: block; object-fit: contain; }
.data-card__title {
  font-family: var(--font-heading); font-weight: 700;
  font-size: 32px; line-height: normal; color: var(--dark); margin: 0;
}
.data-card__text {
  font-family: var(--font-body); font-weight: 400;
  font-size: 20px; line-height: normal; color: var(--dark); margin: 0;
}
@media (max-width: 768px) {
  .data-cards-grid { grid-template-columns: 1fr; }
}

/* Layout/400 — 4 sector cards (300x520, light-green bg, icon 72px, tag, heading, button) */
.sektor-cards-row { display: flex; gap: 26.67px; justify-content: space-between; width: 100%; }
.sektor-card {
  width: 300px; height: 520px;
  background: #dde8dd;
  border-radius: var(--radius-md); padding: 24px;
  display: flex; flex-direction: column; justify-content: space-between;
  overflow: hidden;
}
.sektor-card__top { display: flex; flex-direction: column; gap: 32px; }
.sektor-card__head { display: flex; flex-direction: column; gap: 24px; align-items: flex-start; }
.sektor-card__icon { width: 72px; height: 72px; }
.sektor-card__icon img { width: 100%; height: 100%; display: block; }
.sektor-card__content { display: flex; flex-direction: column; gap: 16px; }
.sektor-card__title {
  font-family: var(--font-heading); font-weight: 800;
  font-size: 24px; line-height: normal; color: var(--dark); margin: 0;
}
.sektor-card__text {
  font-family: var(--font-body);
  font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0;
}
.sektor-card__link {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-body); font-weight: 700; font-size: 18px;
  color: var(--dark); text-decoration: none; align-self: flex-start;
}
.sektor-card__link svg { width: 24px; height: 24px; }

/* Layout/368 — Mixed results: big card left (image+content) + 2 stacked cards right */
.results-mixed { display: flex; gap: 32px; width: 100%; align-items: stretch; }
.results-mixed__main {
  flex: 1 0 0; min-width: 0;
  background: var(--white);
  border-radius: var(--radius-sm); overflow: hidden;
  display: flex; flex-direction: column;
  align-self: stretch;
}
.results-mixed__image { width: 100%; flex: 1 0 0; min-height: 0; overflow: hidden; }
.results-mixed__image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.results-mixed__main-content {
  padding: 32px;
  display: flex; flex-direction: column; gap: 32px; justify-content: space-between;
  height: 416px; box-sizing: border-box;
}
.results-mixed__top { display: flex; flex-direction: column; gap: 16px; align-items: flex-start; }
.results-mixed__heading {
  font-family: var(--font-heading); font-weight: 700;
  font-size: var(--fs-h3); line-height: normal; color: var(--dark); margin: 0;
}
.results-mixed__text {
  font-family: var(--font-body);
  font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0;
}
.results-mixed__side { flex: 1 0 0; min-width: 0; display: flex; flex-direction: column; gap: 32px; }
.results-mixed__card {
  flex: 1 0 0; min-height: 400px;
  background: var(--white);
  border-radius: var(--radius-sm); padding: 32px;
  display: flex; flex-direction: column; gap: 24px; justify-content: space-between;
  box-sizing: border-box;
}
.results-mixed__card > div { display: flex; flex-direction: column; gap: 16px; }
.results-mixed__icon { width: 48px; height: 48px; flex-shrink: 0; }
.results-mixed__icon img, .results-mixed__icon svg { width: 100%; height: 100%; display: block; }
.results-mixed__logo {
  height: 48px;
  display: inline-flex; align-items: center;
  color: var(--green);
  font-family: var(--font-heading); font-weight: 800; font-size: 28px;
}

/* Testimonial/43 — Two-col split sub-elements (card-based markup).
   Scoped under .testimonial-split-section so they DO NOT override the
   primary .testimonial-split { display:flex; gap:80px } rule above. */
.testimonial-split-section .testimonial-split__card {
  background: var(--white);
  border: 1px solid #b4b3b5;
  border-radius: var(--radius-md); padding: 32px;
  display: flex; flex-direction: column; gap: 32px;
}
.testimonial-split-section .testimonial-split__logo { height: 48px; display: inline-flex; align-items: center; }
.testimonial-split-section .testimonial-split__logo img { height: 48px; width: auto; }
.testimonial-split-section .testimonial-split__body { display: flex; flex-direction: column; gap: 24px; }
.testimonial-split-section .testimonial-split__quote {
  font-family: var(--font-heading); font-weight: 600;
  font-size: var(--fs-h5); line-height: normal; color: var(--dark); margin: 0;
}
.testimonial-split-section .testimonial-split__avatar { display: flex; gap: 20px; align-items: center; }
.testimonial-split-section .testimonial-split__avatar-img { width: 64px; height: 64px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.testimonial-split-section .testimonial-split__name {
  font-family: var(--font-body); font-weight: 600; font-size: var(--fs-t2); color: var(--dark); display: block;
}
.testimonial-split-section .testimonial-split__role {
  font-family: var(--font-body); font-weight: 400; font-size: var(--fs-t2); color: var(--dark); display: block;
}
.testimonial-split-section .testimonial-split__cta {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-body); font-weight: 700; font-size: 18px;
  color: var(--dark); text-decoration: none; align-self: flex-start;
  padding: 4px 12px;
}
.testimonial-split-section .testimonial-split__cta svg { width: 24px; height: 24px; }
.testimonial-split-section .testimonial-split__controls { display: flex; gap: 32px; align-items: center; justify-content: center; }

@media (max-width: 1100px) {
  .step-cards-row { flex-wrap: wrap; height: auto; }
  .step-card { flex: 1 0 calc(50% - 12px); height: 380px; }
  .benefit-cards { grid-template-columns: 1fr; }
  .sektor-cards-row { flex-wrap: wrap; justify-content: center; }
  .results-mixed { flex-direction: column; }
  .results-mixed__main, .results-mixed__side { width: 100%; }
  .testimonial-split-section .testimonial-split { flex-direction: column; }
  .testimonial-split-section .testimonial-split__right { width: 100%; }
}
@media (max-width: 768px) {
  .step-cards-row { flex-direction: column; }
  .step-card { width: 100%; flex: none; height: auto; min-height: 320px; }
  .icon-banner-section__heading { font-size: 40px; }
  .sektor-card { width: 100%; height: auto; min-height: 440px; }
  .testimonial-split__heading { font-size: 40px; }
}

/* ========================================
   MICRONICS — sekcje po product header (Figma 25:14841)
   Reuses .feature-grid, .two-col, .icons-section, .testimonial-split,
   .cta-card-section. Adds new patterns for Tabs (Layout/507) and
   asymmetric 3-card row (Layout/367).
   ======================================== */

/* Layout/507 — Tabs section (4 tabs + active panel split image/text) */
.tabs-section { background: var(--white); padding: 100px var(--page-padding); }
.tabs-section__container { max-width: var(--container); margin: 0 auto; display: flex; flex-direction: column; gap: 80px; align-items: stretch; }
.tabs-section__title { max-width: 768px; margin: 0 auto; text-align: center; display: flex; flex-direction: column; gap: 16px; align-items: center; }
.tabs-section__heading { font-family: var(--font-heading); font-weight: 700; font-size: var(--fs-h0); line-height: normal; color: var(--dark); margin: 0; }
.tabs-section__desc { font-family: var(--font-body); font-size: var(--fs-t2); line-height: 1.35; color: var(--dark); margin: 0; }
.tabs-card { border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; }
.tabs-nav { display: flex; border-bottom: 1px solid var(--border); }
.tabs-nav__btn { flex: 1; height: 79px; padding: 24px; font-family: var(--font-heading); font-weight: 700; font-size: var(--fs-h4); line-height: normal; color: var(--dark); text-align: center; background: var(--white); border: none; border-right: 1px solid var(--border); cursor: pointer; transition: background 0.2s, color 0.2s; }
.tabs-nav__btn:last-child { border-right: none; }
.tabs-nav__btn:hover { background: var(--gray-bg); }
.tabs-nav__btn.is-active { background: var(--green); color: var(--white); }
.tabs-panel { padding: 72px; display: flex; gap: 80px; align-items: center; }
.tabs-panel[hidden] { display: none; }
.tabs-panel__content { flex: 0 0 496px; display: flex; flex-direction: column; gap: 32px; }
.tabs-panel__heading { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h1); line-height: normal; color: var(--dark); margin: 0; }
.tabs-panel__text { font-family: var(--font-body); font-size: var(--fs-t2); line-height: 1.35; color: var(--dark); margin: 0; }
.tabs-panel__actions { display: flex; gap: 30px; align-items: center; }
.tabs-panel__media { flex: 1; height: 529px; border-radius: var(--radius-lg); overflow: hidden; background: var(--gray-bg); }
.tabs-panel__media img { width: 100%; height: 100%; object-fit: cover; }

/* Layout/367 — Asymmetric 3-card row (2 stacked left + 1 wide-with-image right) */
.asym-section { background: var(--white); padding: 100px var(--page-padding); }
.asym-section__container { max-width: var(--container); margin: 0 auto; display: flex; flex-direction: column; gap: 80px; }
.asym-section__title { max-width: 768px; margin: 0 auto; text-align: center; display: flex; flex-direction: column; gap: 16px; align-items: center; }
.asym-section__heading { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h1); line-height: normal; color: var(--dark); margin: 0; }
.asym-section__desc { font-family: var(--font-body); font-size: var(--fs-t2); line-height: 1.35; color: var(--dark); margin: 0; }
.asym-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: stretch; }
.asym-cards__col-left { display: flex; flex-direction: column; gap: 32px; }
.asym-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 48px; display: flex; flex-direction: column; gap: 32px; flex: 1; min-height: 383px; }
.asym-card__icon { width: 48px; height: 48px; }
.asym-card__icon img { width: 100%; height: 100%; object-fit: contain; }
.asym-card__heading { font-family: var(--font-heading); font-weight: 700; font-size: var(--fs-h3); line-height: normal; color: var(--dark); margin: 0; }
.asym-card__text { font-family: var(--font-body); font-size: var(--fs-t2); line-height: 1.35; color: var(--dark); margin: 0; }
.asym-card__actions { display: flex; gap: 24px; align-items: center; margin-top: auto; }
.asym-card--with-image { padding: 0; overflow: hidden; }
.asym-card--with-image .asym-card__media { width: 100%; height: 360px; overflow: hidden; background: var(--gray-bg); }
.asym-card--with-image .asym-card__media img { width: 100%; height: 100%; object-fit: cover; }
.asym-card--with-image .asym-card__body { padding: 48px; display: flex; flex-direction: column; gap: 16px; flex: 1; }

/* Layout/16 — split section with media left + content right + checklist + 2 buttons */
.split-media-section { background: var(--white); padding: 100px var(--page-padding); }
.split-media-section__container { max-width: var(--container); margin: 0 auto; display: flex; gap: 80px; align-items: stretch; }
.split-media-section__media { flex: 0 0 600px; }
.split-media-section__media img { width: 100%; height: 640px; border-radius: var(--radius-md); object-fit: cover; }
.split-media-section__content { flex: 1; display: flex; flex-direction: column; gap: 48px; padding: 10px 0; min-width: 0; }
.split-media-section__title-block { display: flex; flex-direction: column; gap: 24px; }
.split-media-section__heading { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h1); line-height: normal; color: var(--dark); margin: 0; }
.split-media-section__desc { font-family: var(--font-body); font-size: var(--fs-t2); line-height: 1.35; color: var(--dark); margin: 0; }
.split-media-section__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 16px; }
.split-media-section__list-item { display: flex; gap: 16px; align-items: center; }
.split-media-section__list-icon { width: 30px; height: 30px; flex-shrink: 0; color: var(--green); display: inline-flex; align-items: center; justify-content: center; }
.split-media-section__list-icon img, .split-media-section__list-icon svg { width: 100%; height: 100%; }
.split-media-section__list-text { font-family: var(--font-body); font-size: var(--fs-t2); line-height: 1.35; color: var(--dark); margin: 0; }
.split-media-section__actions { display: flex; gap: 30px; align-items: center; }

/* Layout/109 — centered intro/tagline + heading + text + 1 button */
.intro-banner-section { background: var(--white); padding: 100px var(--page-padding); }
.intro-banner-section__container { max-width: 1000px; margin: 0 auto; display: flex; flex-direction: column; gap: 80px; align-items: center; text-align: center; }
.intro-banner-section__title { display: flex; flex-direction: column; gap: 16px; align-items: center; }
.intro-banner-section__heading { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h1); line-height: normal; color: var(--dark); margin: 0; }
.intro-banner-section__text { font-family: var(--font-body); font-size: var(--fs-t2); line-height: 1.35; color: var(--dark); margin: 0; }
/* Layout/109 variant — gray-bg wrapper with bordered card inside (Figma 25:14920) */
.intro-banner-section--bordered { background: var(--gray-bg); padding: 100px var(--page-padding); }
.intro-banner-section--bordered .intro-banner-section__container {
  max-width: 1280px;
  width: 100%;
  background: var(--gray-bg);
  border: 1px solid var(--green);
  border-radius: var(--radius-lg);
  padding: 100px 140px;
  gap: 48px;
}
.intro-banner-section--bordered .intro-banner-section__text { white-space: pre-line; }
@media (max-width: 900px) {
  .intro-banner-section--bordered { padding: 60px 24px; }
  .intro-banner-section--bordered .intro-banner-section__container { padding: 48px 24px; gap: 32px; }
}

/* Responsive */
@media (max-width: 1100px) {
  .tabs-panel { flex-direction: column; padding: 32px; gap: 32px; }
  .tabs-panel__content, .tabs-panel__media { flex: 0 0 auto; width: 100%; height: auto; }
  .tabs-panel__media { aspect-ratio: 4/3; }
  .tabs-nav { flex-direction: column; }
  .tabs-nav__btn { width: 100%; border-right: none; border-bottom: 1px solid var(--border); }
  .asym-cards { grid-template-columns: 1fr; }
  .split-media-section__container { flex-direction: column; }
  .split-media-section__media { flex: 0 0 auto; width: 100%; }
  .split-media-section__media img { height: 320px; }
}

/* ========================================
   G-SENSE Energy — nowe komponenty (Figma 25:15229)
   ======================================== */

/* Product Header features list — wariant w jasnozielonym tle */
.product-header__features--card {
  background: #dde8dd;
  border-radius: var(--radius-sm);
  padding: 32px;
}
.product-header__features--card h2 {
  font-size: var(--fs-h5);
  font-weight: 800;
}

/* two-col actions row (Layout/16, /32) */
.two-col__actions {
  display: flex;
  gap: 30px;
  align-items: center;
  margin-top: 32px;
}
.two-col__actions .btn { gap: 8px; }

/* Layout/400 — 4 numbered process cards (light green variant, used by g-sense-energy) */
.process-cards {
  display: flex;
  gap: 24px;
  width: 100%;
  align-items: stretch;
  min-height: 530px;
}
.process-cards > .process-card {
  flex: 1 0 0;
  min-width: 0;
  background: #dde8dd;
  border: 1px solid var(--green);
  border-radius: var(--radius-md);
  padding: 32px 24px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  overflow: hidden;
  color: var(--dark);
  height: auto;
}
.process-cards > .process-card .process-card__num { color: var(--dark); }
.process-cards > .process-card .process-card__title { color: var(--dark); font-size: var(--fs-h4); }
.process-cards > .process-card .process-card__desc { color: var(--dark); line-height: 1.35; }
.process-cards > .process-card .process-card__link { color: var(--dark); }
.process-card__link:hover { opacity: 0.8; }

/* Layout/298 — 4 benefit cards (dark gray) */
.benefit-cards {
  display: flex;
  gap: 48px;
  width: 100%;
  align-items: stretch;
}
.benefit-card {
  flex: 1 0 0;
  min-width: 0;
  background: var(--gray-mid2);
  border-radius: var(--radius-md);
  padding: 32px 24px;
  display: flex;
  flex-direction: column;
  gap: 24px;
  color: var(--white);
  align-items: center;
  text-align: center;
}
.benefit-card__icon { width: 48px; height: 48px; color: var(--white); flex-shrink: 0; }
.benefit-card__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h4);
  line-height: normal;
  color: var(--white);
  margin: 0;
}
.benefit-card__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t3);
  line-height: 1.35;
  color: var(--white);
  margin: 0;
}

/* Case-study benefits override — white card on gray bg, dark text, left-aligned (Figma 25:12675) */
.persona-benefits-section .benefit-card {
  background: var(--white);
  color: var(--dark);
  align-items: flex-start;
  text-align: left;
  border-radius: var(--radius-md);
}
.persona-benefits-section .benefit-card__icon { color: var(--green); }
.persona-benefits-section .benefit-card__icon img { width: 48px; height: 48px; display: block; }
.persona-benefits-section .benefit-card__title { color: var(--dark); }
.persona-benefits-section .benefit-card__text {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.5;
  color: var(--dark);
  margin: 0;
}

/* Layout/31 — 2x2 value cards (green) */
.value-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  width: 100%;
}
.value-card {
  background: var(--green);
  border-radius: var(--radius-md);
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  color: var(--white);
  align-items: flex-start;
}
.value-card__icon { width: 48px; height: 48px; color: var(--white); flex-shrink: 0; }
.value-card__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h4);
  line-height: normal;
  color: var(--white);
  margin: 0;
}
.value-card__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--white);
  margin: 0;
}
.value-card .btn--white { margin-top: 16px; align-self: flex-start; }

/* Layout/395 — 3 industry cards (white bordered) */
.industry-cards {
  display: flex;
  gap: 64px;
  width: 100%;
  align-items: stretch;
}
.industry-card {
  flex: 1 0 0;
  min-width: 0;
  height: 520px;
  background: var(--white);
  border: 1px solid var(--green);
  border-radius: var(--radius-md);
  padding: 24px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  overflow: hidden;
}
.industry-card__top { display: flex; flex-direction: column; gap: 16px; }
.industry-card__icon { width: 72px; height: 72px; color: var(--green); margin-bottom: 8px; }
.industry-card__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h4);
  line-height: normal;
  color: var(--dark);
  margin: 16px 0 0;
}
.industry-card__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--dark);
  margin: 0;
}
.industry-card__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 18px;
  color: var(--dark);
}
.industry-card__link svg { width: 24px; height: 24px; }

/* Layout/32 — relume bullet list */
.relume-list {
  display: flex;
  flex-direction: column;
  gap: 32px;
  list-style: none;
  padding: 8px 0;
  margin: 0;
  width: 100%;
}
.relume-item { display: flex; gap: 24px; align-items: flex-start; width: 100%; }
.relume-bullet {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.relume-bullet::before {
  content: "";
  display: block;
  width: 32px;
  height: 30.5px;
  background: var(--green);
  border-radius: 24.6px;
}
.relume-content {
  flex: 1 0 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.relume-title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h3);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.relume-desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--dark);
  margin: 0;
}

/* Testimonial / 43 */
.testimonial-43 { display: flex; gap: 80px; align-items: center; width: 100%; }
.testimonial-43__card {
  flex: 1 0 0;
  min-width: 0;
  background: var(--white);
  border-radius: var(--radius-md);
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.testimonial-43__logo { width: 120px; height: 48px; object-fit: contain; align-self: flex-start; }
.testimonial-43__quote {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 22px;
  line-height: 1.4;
  color: var(--dark);
  margin: 0;
}
.testimonial-43__author { display: flex; gap: 20px; align-items: center; }
.testimonial-43__avatar {
  width: 64px; height: 64px;
  border-radius: 50%;
  background: var(--gray-bg);
  flex-shrink: 0;
}
.testimonial-43__author-info { display: flex; flex-direction: column; gap: 2px; }
.testimonial-43__name { font-family: var(--font-body); font-weight: 700; font-size: 18px; color: var(--dark); margin: 0; }
.testimonial-43__role { font-family: var(--font-body); font-size: 16px; color: var(--gray-mid); margin: 0; }
.testimonial-43__cta {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-body); font-weight: 700; font-size: 18px; color: var(--dark);
  margin-top: 8px;
}
.testimonial-43__cta svg { width: 24px; height: 24px; }
.testimonial-43__side { flex: 1 0 0; min-width: 0; display: flex; flex-direction: column; gap: 16px; }
.testimonial-43__heading {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h1);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.testimonial-43__lead {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--dark);
  margin: 0;
}

@media (max-width: 1100px) {
  .process-cards { flex-wrap: wrap; }
  .process-card { flex: 1 0 calc(50% - 12px); }
  .benefit-cards { flex-wrap: wrap; }
  .benefit-card { flex: 1 0 calc(50% - 24px); }
  .industry-cards { flex-wrap: wrap; }
  .industry-card { flex: 1 0 calc(50% - 32px); height: auto; min-height: 420px; }
  .testimonial-43 { flex-direction: column; gap: 40px; }
}
@media (max-width: 768px) {
  .process-cards, .benefit-cards, .industry-cards { flex-direction: column; }
  .process-card, .benefit-card { width: 100%; }
  .industry-card { width: 100%; height: auto; min-height: 380px; }
  .value-cards { grid-template-columns: 1fr; }
}

/* ============================================================
   PROGRAM PILOTAŻOWY (PoC) (Figma 25:12085)
   ============================================================ */

/* Layout/369 — 3 cards 410x400 light gray with tag + heading + text + button */
.poc-cards-row { display: flex; gap: 24px; width: 100%; height: 400px; }
.poc-card {
  flex: 1 0 0; min-width: 0;
  background: var(--gray-mid2, #b4b3b5);
  border-radius: var(--radius-md); padding: 32px 24px;
  display: flex; flex-direction: column; justify-content: space-between;
  overflow: hidden;
}
.poc-card__top { display: flex; flex-direction: column; gap: 32px; }
.poc-card__content { display: flex; flex-direction: column; gap: 16px; }
.poc-card__title {
  font-family: var(--font-heading); font-weight: 700;
  font-size: var(--fs-h3-5); line-height: normal; color: var(--dark); margin: 0;
}
.poc-card__text {
  font-family: var(--font-body);
  font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0;
}
.poc-card__link {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-body); font-weight: 700; font-size: 18px;
  color: var(--dark); text-decoration: none; align-self: flex-start;
}
.poc-card__link svg { width: 24px; height: 24px; }

/* Timeline/8 — Centered 768px column: title block + buttons + timeline cards */
.poc-timeline-section { background: var(--white); padding: 100px var(--page-padding); }
.poc-timeline-section__container { max-width: var(--container); margin: 0 auto; display: flex; justify-content: center; }
.poc-timeline-section__column { max-width: 768px; width: 100%; display: flex; flex-direction: column; gap: 80px; }
.poc-timeline-section__title-block { display: flex; flex-direction: column; gap: 32px; }
.poc-timeline-section__title-content { display: flex; flex-direction: column; gap: 16px; }
.poc-timeline-section__heading {
  font-family: var(--font-heading); font-weight: 800;
  font-size: var(--fs-h1); line-height: normal; color: var(--dark); margin: 0;
}
.poc-timeline-section__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0;
}
.poc-timeline-section__actions { display: flex; gap: 30px; align-items: center; }
.poc-timeline { display: flex; flex-direction: column; width: 100%; }
.poc-timeline__item { display: flex; gap: 48px; align-items: stretch; width: 100%; }
.poc-timeline__progress { width: 32px; display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 0 8.5px; }
.poc-timeline__divider { background: var(--green); width: 3px; flex: 1 0 0; min-height: 8px; border-radius: 1.5px; }
.poc-timeline__divider--head { flex: none; height: 24px; }
.poc-timeline__divider--top { flex: none; height: 42px; }
.poc-timeline__bullet { width: 15px; height: 15px; flex-shrink: 0; background: var(--green); border-radius: 50%; }
.poc-timeline__item:first-child .poc-timeline__divider:first-child { visibility: hidden; }
.poc-timeline__item:last-child .poc-timeline__divider:last-child { visibility: hidden; }
.poc-timeline__date-col { flex: 1 0 0; min-width: 0; padding: 24px 0; }
.poc-timeline__card {
  background: #dde8dd;
  border-radius: var(--radius-md); padding: 32px;
  display: flex; flex-direction: column; gap: 32px;
}
.poc-timeline__titles { display: flex; flex-direction: column; gap: 16px; }
.poc-timeline__date {
  font-family: var(--font-heading); font-weight: 700;
  font-size: 50px; line-height: normal; color: var(--dark); margin: 0;
}
.poc-timeline__heading {
  font-family: var(--font-heading); font-weight: 700;
  font-size: var(--fs-h3-5); line-height: normal; color: var(--dark); margin: 0;
}
.poc-timeline__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0;
}

/* Layout/395 — 3 kit cards 400x700 (image top + tag + heading + text + 2 link buttons) */
.kit-cards-row { display: flex; gap: 40px; justify-content: space-between; width: 100%; }
.kit-card {
  width: 400px; height: 700px;
  background: var(--white);
  border-radius: var(--radius-md); overflow: hidden;
  display: flex; flex-direction: column;
}
.kit-card__image { width: 100%; aspect-ratio: 400/266; overflow: hidden; }
.kit-card__image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.kit-card__body { flex: 1; padding: 24px; display: flex; flex-direction: column; justify-content: space-between; gap: 20px; }
.kit-card__top { display: flex; flex-direction: column; gap: 20px; }
.kit-card__content { display: flex; flex-direction: column; gap: 16px; }
.kit-card__title {
  font-family: var(--font-heading); font-weight: 800;
  font-size: var(--fs-h3-5); line-height: normal; color: var(--dark); margin: 0;
}
.kit-card__text {
  font-family: var(--font-body);
  font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0;
}
.kit-card__actions { display: flex; gap: 24px; align-items: center; }
.kit-card__link {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-body); font-weight: 700; font-size: 18px;
  color: var(--dark); text-decoration: none;
}
.kit-card__link svg { width: 24px; height: 24px; }

/* Layout/501 — Section title + 3 tabs + image-content split */
.report-section { background: var(--white); padding: 100px var(--page-padding); }
.report-section__container {
  max-width: var(--container); margin: 0 auto;
  display: flex; flex-direction: column; gap: 100px; align-items: center;
}
.report-section__head {
  max-width: 768px; width: 100%;
  display: flex; flex-direction: column; gap: 60px; align-items: center; text-align: center;
}
.report-section__title-block { display: flex; flex-direction: column; gap: 16px; align-items: center; width: 100%; }
.report-section__title-content { display: flex; flex-direction: column; gap: 24px; align-items: center; width: 100%; }
.report-section__heading {
  font-family: var(--font-heading); font-weight: 800;
  font-size: var(--fs-h1); line-height: normal; color: var(--dark); margin: 0;
}
.report-section__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0;
}
.report-section__actions { display: flex; gap: 30px; align-items: center; }
.report-tabs { width: 100%; display: flex; flex-direction: column; gap: 64px; padding: 32px 0; }
.report-tabs__menu { display: flex; gap: 24px; align-items: center; justify-content: center; }
.report-tab {
  height: 50px; padding: 10px 24px;
  border-radius: var(--radius-sm);
  border: 1px solid transparent; background: var(--white);
  font-family: var(--font-body); font-size: var(--fs-t2);
  font-weight: 400; color: var(--dark); cursor: pointer; white-space: nowrap;
}
.report-tab--active { border-color: var(--green); color: var(--green); font-weight: 700; }
.report-content { display: flex; gap: 80px; align-items: center; width: 100%; height: 640px; }
.report-content__image { flex: 1 0 0; min-width: 0; height: 100%; border-radius: var(--radius-lg); overflow: hidden; }
.report-content__image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.report-content__text { flex: 1 0 0; min-width: 0; display: flex; flex-direction: column; gap: 60px; }
.report-content__title-block { display: flex; flex-direction: column; gap: 16px; }
.report-content__title-content { display: flex; flex-direction: column; gap: 24px; }
.report-content__heading {
  font-family: var(--font-heading); font-weight: 800;
  font-size: var(--fs-h1); line-height: normal; color: var(--dark); margin: 0;
}
.report-content__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0;
}
.report-content__actions { display: flex; gap: 30px; align-items: center; }
.btn--soft-green { background: #dde8dd; color: var(--dark); }

/* FAQ/4 — Section title + accordion list */
.faq-section { background: var(--white); padding: 100px var(--page-padding); display: flex; flex-direction: column; gap: 80px; align-items: center; }
.faq-section__container {
  max-width: var(--container); width: 100%;
  display: flex; flex-direction: column; gap: 80px; align-items: center;
}
.faq-section__title {
  max-width: 768px; width: 100%;
  display: flex; flex-direction: column; gap: 24px; align-items: center; text-align: center;
}
.faq-section__heading {
  font-family: var(--font-heading); font-weight: 800;
  font-size: var(--fs-h1); line-height: normal; color: var(--dark); margin: 0;
}
.faq-section__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0;
}
.faq-list { width: 768px; max-width: 100%; display: flex; flex-direction: column; gap: 16px; }
.faq-item { background: #dde8dd; border-radius: var(--radius-sm); overflow: hidden; }
.faq-item__question {
  width: 100%; padding: 24px;
  display: flex; align-items: center; gap: 24px;
  background: none; border: none; cursor: pointer; text-align: left;
}
.faq-item__question-text {
  flex: 1 0 0; min-width: 0;
  font-family: var(--font-heading); font-weight: 800;
  font-size: var(--fs-h5); line-height: normal; color: var(--dark); margin: 0;
}
.faq-item__toggle { width: 24px; height: 24px; flex-shrink: 0; color: var(--dark); }
.faq-item__answer { padding: 0 24px 24px; }
.faq-item__answer p {
  font-family: var(--font-body);
  font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0;
}

/* CTA inside FAQ — gray card */
.cta-banner--gray { background: var(--gray-mid2, #666); }

/* Opinie Google / 8 — Centered stars + huge quote + avatar + name + logo + side chevrons */
.google-review-section {
  background: var(--gray-bg);
  padding: 100px var(--page-padding);
  position: relative;
  display: flex; align-items: center; justify-content: center;
}
.google-review-section__container {
  max-width: var(--container); width: 100%;
  display: flex; flex-direction: column; align-items: center;
  position: relative;
}
.google-review {
  width: 900px; max-width: 100%;
  display: flex; flex-direction: column; gap: 32px; align-items: center; text-align: center;
}
.google-review__stars { display: inline-flex; gap: 4px; height: 21px; align-items: center; color: #fbbf24; }
.google-review__stars svg { width: 21px; height: 21px; }
.google-review__quote {
  font-family: var(--font-heading); font-weight: 800;
  font-size: 36px; line-height: 1.5; color: var(--dark); margin: 0;
}
.google-review__attribution {
  display: flex; gap: 20px; align-items: center; justify-content: center;
}
.google-review__person { display: flex; gap: 20px; align-items: center; }
.google-review__avatar { width: 64px; height: 64px; border-radius: 50%; object-fit: cover; }
.google-review__name {
  font-family: var(--font-body); font-weight: 700; font-size: var(--fs-t2); color: var(--dark);
  display: block; line-height: 1.5;
}
.google-review__role {
  font-family: var(--font-body); font-weight: 400; font-size: var(--fs-t3); color: var(--dark);
  display: block; line-height: normal;
}
.google-review__divider { width: 1px; height: 65px; background: var(--dark); opacity: 0.2; }
.google-review__logo {
  height: 48px; display: inline-flex; align-items: center;
}
.google-review__logo img { height: 48px; width: auto; }
.google-review__chevron {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 48px; height: 48px;
  background: transparent; border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: var(--dark);
}
.google-review__chevron svg { width: 24px; height: 24px; }
.google-review__chevron--prev { left: 48px; }
.google-review__chevron--next { right: 48px; }
.google-review__chevron:hover { opacity: 0.7; }

@media (max-width: 1100px) {
  .poc-cards-row { flex-wrap: wrap; height: auto; }
  .poc-card { flex: 1 0 calc(50% - 12px); height: 360px; }
  .kit-cards-row { flex-wrap: wrap; justify-content: center; }
  .kit-card { height: auto; min-height: 600px; }
  .report-content { flex-direction: column; height: auto; }
  .report-content__image { width: 100%; aspect-ratio: 600/400; flex: none; }
  .report-tabs__menu { flex-wrap: wrap; }
  .google-review__chevron--prev { left: 8px; }
  .google-review__chevron--next { right: 8px; }
}
@media (max-width: 768px) {
  .poc-cards-row { flex-direction: column; }
  .poc-card { width: 100%; flex: none; height: auto; min-height: 320px; }
  .poc-timeline-section__heading,
  .faq-section__heading,
  .report-section__heading { font-size: 40px; }
  .poc-timeline__item { gap: 24px; }
  .poc-timeline__date { font-size: 36px; }
  .kit-card { width: 100%; }
  .google-review__quote { font-size: 24px; }
  .google-review__attribution { flex-direction: column; gap: 16px; }
  .google-review__divider { display: none; }
}

/* ========================================
   Kontakt — Contact / 14 (Figma 25:11862)
   ======================================== */
.contact-list {
  display: flex;
  gap: 40px;
  width: 100%;
  align-items: stretch;
  margin-top: 80px;
}
.contact-list-item {
  flex: 1 0 0;
  min-width: 0;
  background: var(--white);
  border-radius: var(--radius-md);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  color: var(--green);
}
.contact-list-item__icon {
  width: 48px;
  height: 48px;
  color: var(--green);
  flex-shrink: 0;
}
.contact-list-item__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h4);
  line-height: normal;
  color: var(--green);
  margin: 0;
}
.contact-list-item__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--green);
  margin: 0;
}
.contact-list-item__link {
  font-family: var(--font-body);
  font-weight: 700;
  font-size: var(--fs-t2);
  color: var(--green);
  text-decoration: none;
}
.contact-list-item__link:hover { opacity: 0.85; }
.contact-list-item__link--arrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.contact-list-item__link--arrow svg { width: 24px; height: 24px; }

.contact-map {
  margin-top: 80px;
  width: 100%;
  height: 516px;
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.contact-map iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

@media (max-width: 1100px) {
  .contact-list { flex-direction: column; }
  .contact-list-item { width: 100%; }
}

/* ========================================
   DOKUMENTACJA do pobrania (Figma 25:11939)
   ======================================== */

/* Header / 62 / — centered hero: tagline + giant H0 + sub + 1 button */
.docs-hero { background: var(--gray-bg); padding: 112px var(--page-padding); }
.docs-hero__inner { max-width: 768px; margin: 0 auto; text-align: center; display: flex; flex-direction: column; gap: 32px; align-items: center; }
.docs-hero__title-block { display: flex; flex-direction: column; gap: 16px; align-items: center; width: 100%; }
.docs-hero__heading { font-family: var(--font-heading); font-weight: 800; font-size: var(--fs-h0); line-height: normal; color: var(--dark); margin: 0; }
.docs-hero__sub { font-family: var(--font-body); font-size: var(--fs-t2); line-height: 1.35; color: var(--dark); margin: 0; }

/* Content / 7 / — 800px column with 7 product cards */
.docs-list { background: var(--white); padding: 112px var(--page-padding); }
.docs-list__container { max-width: 800px; margin: 0 auto; display: flex; flex-direction: column; gap: 80px; }
.docs-card { border: 2px solid var(--green); border-radius: var(--radius-md); padding: 24px; display: flex; flex-direction: column; gap: 24px; align-items: center; text-align: center; }
.docs-card__heading { font-family: var(--font-heading); font-weight: 700; font-size: 50px; line-height: 1.3; color: var(--dark); margin: 0; }
.docs-card__actions { display: flex; gap: 16px; align-items: center; justify-content: center; flex-wrap: wrap; }
.docs-btn { display: inline-flex; align-items: center; gap: 8px; height: 40px; padding: 8px 12px; background: var(--green); color: var(--white); border-radius: var(--radius-sm); font-family: var(--font-body); font-weight: 400; font-size: 16px; text-decoration: none; white-space: nowrap; transition: opacity 0.2s, background 0.2s; }
.docs-btn svg { width: 24px; height: 24px; }
.docs-btn:hover { opacity: 0.9; }
.docs-card--featured { background: var(--green); border-color: var(--green); color: var(--white); }
.docs-card--featured .docs-card__heading { color: var(--white); }
.docs-card--featured .docs-btn { background: rgba(255, 255, 255, 0.15); color: var(--white); }
.docs-card--featured .docs-btn:hover { background: rgba(255, 255, 255, 0.25); opacity: 1; }

@media (max-width: 700px) {
  .docs-hero, .docs-list { padding: 80px 24px; }
  .docs-hero__heading { font-size: 48px; }
  .docs-card__heading { font-size: 36px; }
}

/* ========================================
   CFO/ZARZĄD strona (Figma 25:16509) — dodatki
   ======================================== */

/* Result card variant: green featured (for Layout/522 middle wide card) */
.result-card--featured { background: var(--green); color: var(--white); }
.result-card--featured .result-card__title,
.result-card--featured .result-card__desc { color: var(--white); }

/* Split-media reverse (image on RIGHT instead of LEFT) — for Layout/105 */
.split-media-section--reverse .split-media-section__container { flex-direction: row-reverse; }

/* Layout/365 — 1 tall card left + 2 horizontal cards stacked right */
.layout365-row { display: grid; grid-template-columns: 608px 1fr; gap: 32px; width: 100%; align-items: stretch; }
.layout365-main {
  background: var(--gray-bg);
  border-radius: var(--radius-md);
  overflow: hidden;
  display: flex; flex-direction: column;
}
.layout365-main__image { width: 100%; height: 420px; overflow: hidden; background: var(--gray-bg); }
.layout365-main__image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.layout365-main__body { padding: 48px; display: flex; flex-direction: column; gap: 32px; flex: 1; }
.layout365-main__top { display: flex; flex-direction: column; gap: 16px; }
.layout365-main__heading { font-family: var(--font-heading); font-weight: 700; font-size: var(--fs-h3); line-height: normal; color: var(--dark); margin: 0; }
.layout365-main__text { font-family: var(--font-body); font-size: var(--fs-t2); line-height: 1.35; color: var(--dark); margin: 0; }
.layout365-main__actions { display: flex; gap: 24px; align-items: center; }

.layout365-side { display: flex; flex-direction: column; gap: 32px; }
.layout365-side__card {
  background: var(--gray-bg);
  border-radius: var(--radius-md);
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 420px;
  align-items: stretch;
}
.layout365-side__card--reverse { grid-template-columns: 1fr 1fr; }
.layout365-side__card--reverse .layout365-side__image { order: 1; }
.layout365-side__card--reverse .layout365-side__content { order: 2; }
.layout365-side__image { background: var(--gray-bg); overflow: hidden; }
.layout365-side__image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.layout365-side__content { padding: 32px 24px; display: flex; flex-direction: column; gap: 32px; justify-content: center; }
.layout365-side__top { display: flex; flex-direction: column; gap: 16px; }
.layout365-side__heading { font-family: var(--font-heading); font-weight: 700; font-size: var(--fs-h3-5); line-height: normal; color: var(--dark); margin: 0; }
.layout365-side__text { font-family: var(--font-body); font-size: var(--fs-t3); line-height: 1.5; color: var(--dark); margin: 0; }

@media (max-width: 1100px) {
  .layout365-row, .layout365-side__card { grid-template-columns: 1fr; }
  .layout365-main__image { height: 280px; }
  .split-media-section--reverse .split-media-section__container { flex-direction: column; }
}

/* ========================================
   Twoja Rola / Dyrektor produkcji (Figma 25:16301)
   ======================================== */

/* Layout — 4 persona cards (image bg + dark overlay) */
.persona-cards {
  display: flex;
  gap: 32px;
  width: 100%;
  align-items: stretch;
}
.persona-card {
  flex: 1 0 0;
  min-width: 0;
  height: 420px;
  position: relative;
  border-radius: var(--radius-md);
  overflow: hidden;
  padding: 24px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  color: var(--white);
}
.persona-card__bg, .persona-card__overlay { position: absolute; inset: 0; z-index: 0; }
.persona-card__bg img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.persona-card__overlay { background: rgba(0,0,0,0.65); }
.persona-card__top, .persona-card__link { position: relative; z-index: 1; }
.persona-card__top { display: flex; flex-direction: column; gap: 12px; }
.persona-card__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h4);
  line-height: normal;
  color: var(--white);
  margin: 0;
  max-width: 244px;
}
.persona-card__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--white);
  margin: 0;
}
.persona-card__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 18px;
  color: var(--white);
}
.persona-card__link svg { width: 24px; height: 24px; }
.persona-card__link:hover { opacity: 0.85; }

/* Layout / 513 — 4 filary (full-width rows, alternating align) */
.filar-rows {
  display: flex;
  flex-direction: column;
  gap: 100px;
  width: 100%;
}
.filar-row {
  display: flex;
  flex-direction: column;
  gap: 32px;
  align-items: flex-start;
  width: 100%;
}
.filar-row--right { align-items: flex-end; text-align: right; }
.filar-row__head {
  display: flex;
  flex-direction: column;
  gap: 16px;
  color: var(--green);
  width: 100%;
}
.filar-row--right .filar-row__head { align-items: flex-end; }
.filar-row__num {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 100px;
  line-height: 1;
}
.filar-row__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 50px;
  line-height: normal;
  text-transform: uppercase;
  margin: 0;
  width: 100%;
}
.filar-row--right .filar-row__title { text-align: right; }
.filar-row__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--dark);
  margin: 0;
  width: 100%;
}
.filar-row--right .filar-row__desc { text-align: right; }
.filar-row__image {
  width: 100%;
  height: 392px;
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.filar-row__image img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}

/* Layout / 378 — Branże asymmetric grid */
.branze-grid {
  display: flex;
  gap: 32px;
  width: 100%;
  align-items: stretch;
}
.branze-grid__col {
  flex: 1 0 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 32px;
}
.branze-grid__row {
  display: flex;
  gap: 32px;
  align-items: stretch;
}
.branza-card {
  background: var(--white);
  border-radius: var(--radius-md);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.branza-card--large { flex: 1 0 0; min-width: 0; }
.branza-card--large .branza-card__image {
  height: 300px;
  width: 100%;
}
.branza-card--large .branza-card__body {
  padding: 48px;
  display: flex;
  flex-direction: column;
  gap: 32px;
  flex: 1;
}
.branza-card--wide {
  flex-direction: row;
  align-items: stretch;
}
.branza-card--wide .branza-card__image {
  flex: 1 0 0;
  min-width: 0;
}
.branza-card--wide .branza-card__body {
  flex: 1 0 0;
  min-width: 0;
  padding: 32px 24px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 16px;
}
.branza-card__image img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.branza-card__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 50px;
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.branza-card__title--small { font-size: var(--fs-h4); }
.branza-card__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--dark);
  margin: 0;
}
.branza-card__actions {
  display: flex;
  gap: 24px;
  align-items: center;
  margin-top: auto;
}

.branza-mini {
  flex: 1 0 0;
  min-width: 0;
  background: var(--white);
  border-radius: var(--radius-md);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-height: 350px;
}
.branza-mini__icon {
  width: 48px;
  height: 48px;
  color: var(--green);
  flex-shrink: 0;
}
.branza-mini__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h4);
  line-height: normal;
  color: var(--dark);
  margin: 0;
}
.branza-mini__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t3);
  line-height: 1.35;
  color: var(--dark);
  margin: 0;
  flex: 1;
}
.branza-mini__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 18px;
  color: var(--dark);
  margin-top: auto;
}
.branza-mini__link svg { width: 24px; height: 24px; }
.branza-mini__link:hover { opacity: 0.85; }

/* Layout / 93 — Pilot bordered box */
.pilot-box {
  border: 1px solid var(--green);
  border-radius: var(--radius-lg);
  padding: 64px;
  max-width: var(--container);
  margin: 0 auto;
}
.pilot-box__inner {
  max-width: 1000px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 60px;
  align-items: center;
}
.pilot-box__features {
  display: flex;
  gap: 64px;
  justify-content: center;
  width: 100%;
}
.pilot-feature {
  flex: 0 0 400px;
  background: #dde8dd;
  border-radius: var(--radius-md);
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.pilot-feature__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--fs-h4);
  line-height: normal;
  color: var(--green);
  margin: 0;
}
.pilot-feature__desc {
  font-family: var(--font-body);
  font-size: var(--fs-t2);
  line-height: 1.35;
  color: var(--dark);
  margin: 0;
}

@media (max-width: 1100px) {
  .persona-cards { flex-wrap: wrap; }
  .persona-card { flex: 1 0 calc(50% - 16px); min-width: 280px; }
  .filar-row__title { font-size: 40px; }
  .filar-row__num { font-size: 80px; }
  .branze-grid { flex-direction: column; }
  .branza-card--large .branza-card__body { padding: 32px; }
  .branze-grid__row { flex-direction: column; }
  .branza-mini { min-height: auto; }
  .pilot-box { padding: 32px; }
  .pilot-box__features { flex-direction: column; gap: 24px; }
  .pilot-feature { flex: 1 1 100%; }
}
@media (max-width: 768px) {
  .persona-cards { flex-direction: column; }
  .persona-card { width: 100%; height: auto; min-height: 380px; }
  .branza-card--wide { flex-direction: column; }
  .branza-card--wide .branza-card__image { height: 200px; }
}

/* ========================================
   O FIRMIE — asymmetric mixed cards
   (Layout/368, Layout/387 — kompetencje, ESG)
   ======================================== */
.of-mixed-row { display: flex; gap: 32px; align-items: stretch; width: 100%; }
.of-mixed-col { display: flex; flex-direction: column; gap: 32px; flex: 1 1 0; min-width: 0; }
.of-card {
  display: flex;
  flex-direction: column;
  background: var(--gray-bg);
  border-radius: 16px;
  overflow: hidden;
  flex: 1 1 0;
  min-width: 0;
}
.of-card--green { background: #dde8dd; }
.of-card__img {
  height: 360px;
  width: 100%;
  display: block;
  object-fit: cover;
  flex-shrink: 0;
}
.of-card__body {
  display: flex;
  flex-direction: column;
  gap: 32px;
  padding: 48px;
  flex: 1 1 auto;
  justify-content: space-between;
}
.of-card__top { display: flex; flex-direction: column; gap: 24px; }
.of-card__tag {
  align-self: flex-start;
  background: var(--green);
  color: var(--white);
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 16px;
  line-height: 1.5;
  padding: 4px 10px;
  border-radius: 4px;
}
.of-card__icon { width: 48px; height: 48px; display: block; }
.of-card__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 42px;
  line-height: 1.1;
  color: var(--dark);
  margin: 0;
}
.of-card__title--big { font-size: 50px; }
.of-card__desc {
  font-family: var(--font-body);
  font-size: 20px;
  line-height: 1.4;
  color: var(--dark);
  margin: 0;
}
.of-card__actions { display: flex; gap: 24px; align-items: center; }
.of-card__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--white);
  color: var(--dark);
  font-family: var(--font-body);
  font-size: 20px;
  text-decoration: none;
  height: 50px;
  padding: 10px 24px;
  border-radius: 8px;
  border: 1px solid rgba(7,3,9,0.1);
}
.of-card__link svg { width: 16px; height: 16px; }

/* O firmie — partner logo block (text + 2x2 logo grid) */
.of-logo-section { display: flex; gap: 80px; align-items: center; justify-content: space-between; width: 100%; max-width: var(--container); margin: 0 auto; }
.of-logo-section__content { flex: 0 0 600px; max-width: 600px; display: flex; flex-direction: column; gap: 32px; }
.of-logo-section__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-h1);
  line-height: 1.05;
  color: var(--dark);
  margin: 0;
}
.of-logo-section__desc {
  font-family: var(--font-body);
  font-size: 20px;
  line-height: 1.4;
  color: var(--dark);
  margin: 0;
}
.of-logo-section__actions { display: flex; gap: 30px; align-items: center; }
.of-logo-grid {
  display: grid;
  grid-template-columns: repeat(2, 264px);
  gap: 48px;
  flex-shrink: 0;
}
.of-logo-grid__cell {
  background: var(--white);
  border-radius: 12px;
  padding: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 468 / 240;
}
.of-logo-grid__cell img { max-width: 100%; max-height: 100%; object-fit: contain; display: block; }

/* O firmie — team rectangular grid (2x2 large cards w/ social) */
.of-team-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 64px;
  width: 100%;
}
.of-team-card { display: flex; flex-direction: column; gap: 24px; align-items: center; }
.of-team-card__photo {
  width: 100%;
  aspect-ratio: 608 / 405;
  border-radius: 16px;
  overflow: hidden;
  background: var(--gray-bg);
}
.of-team-card__photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.of-team-card__content { display: flex; flex-direction: column; gap: 16px; align-items: center; width: 100%; text-align: center; }
.of-team-card__title { display: flex; flex-direction: column; gap: 8px; align-items: center; width: 100%; }
.of-team-card__name {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 32px;
  color: var(--dark);
  margin: 0;
}
.of-team-card__role {
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 20px;
  color: var(--dark);
  margin: 0;
}
.of-team-card__bio {
  font-family: var(--font-body);
  font-size: 20px;
  line-height: 1.4;
  color: var(--dark);
  margin: 0;
}
.of-team-card__social { display: flex; gap: 12px; align-items: center; }
.of-team-card__social a { width: 24px; height: 24px; display: inline-flex; align-items: center; justify-content: center; }
.of-team-card__social img { width: 100%; height: 100%; display: block; }

/* O firmie — mission Section Title spacing */
.of-mission { display: flex; flex-direction: column; gap: 32px; align-items: center; max-width: 768px; margin: 0 auto; text-align: center; }
.of-mission__actions { display: flex; gap: 30px; align-items: center; }

@media (max-width: 1100px) {
  .of-mixed-row { flex-direction: column; }
  .of-logo-section { flex-direction: column; gap: 48px; }
  .of-logo-section__content { flex: 0 0 auto; max-width: 100%; }
}
@media (max-width: 768px) {
  .of-team-grid { grid-template-columns: 1fr; gap: 40px; }
  .of-card__body { padding: 32px; }
  .of-card__title { font-size: 32px; }
  .of-card__title--big { font-size: 36px; }
  .of-logo-grid { grid-template-columns: 1fr; }
  .of-logo-section__title { font-size: 40px; }
}

/* ============================================================
   G-SENSE MES — Layout/22: two-col image left (600x640) + content right
   ============================================================ */
.lekki-section { background: var(--white); padding: 100px var(--page-padding); }
.lekki-section__container { max-width: var(--container); margin: 0 auto; }
.lekki-section__row { display: flex; gap: 80px; align-items: center; width: 100%; }
.lekki-section__media {
  flex: 1 0 0; min-width: 0;
  aspect-ratio: 600 / 640;
  border-radius: 32px;
  overflow: hidden;
}
.lekki-section__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.lekki-section__content { flex: 1 0 0; min-width: 0; display: flex; flex-direction: column; gap: 32px; align-items: flex-start; }
.lekki-section__title-block { display: flex; flex-direction: column; gap: 16px; align-items: flex-start; width: 100%; }
.lekki-section__icon { width: 72px; height: 72px; flex-shrink: 0; }
.lekki-section__icon img { width: 100%; height: 100%; display: block; }
.lekki-section__text-block { display: flex; flex-direction: column; gap: 24px; width: 100%; }
.lekki-section__heading {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 64px;
  line-height: 1;
  color: var(--dark);
  margin: 0;
}
.lekki-section__desc {
  font-family: var(--font-body);
  font-size: 20px;
  line-height: 1.35;
  color: var(--dark);
  margin: 0;
}
.lekki-section__actions { display: flex; gap: 30px; align-items: center; flex-wrap: wrap; }
.lekki-section__btn-secondary { display: inline-flex; align-items: center; gap: 8px; background: var(--white); color: var(--dark); border: 1px solid #999; }
.lekki-section__btn-secondary svg { width: 24px; height: 24px; }

/* G-SENSE MES — Layout/396 patch: bordered metric cards with green chevron button */
.metric-card--bordered { background: var(--white); border: 4px solid var(--green); padding: 32px; align-items: center; }
.metric-card--bordered .metric-card__icon { width: 48px; height: 48px; color: var(--green); }
.metric-card--bordered .metric-card__icon img { width: 100%; height: 100%; display: block; }
.metric-card--bordered .metric-card__top { gap: 32px; }
.metric-card__btn { display: inline-flex; align-items: center; gap: 8px; padding: 10px 24px; }
.metric-card__btn svg { width: 24px; height: 24px; }

/* G-SENSE MES — Layout/376 patch: industry small icons 72px (not 48), 2-line headings */
.industry-card-small__icon--lg { width: 72px; height: 72px; }
.industry-card-small__icon--lg img { width: 100%; height: 100%; object-fit: contain; display: block; }

/* G-SENSE MES — Layout/376 patch: bigger card heights to match Figma 424px per row */
[data-figma-id="25:14606"] .industries-grid { align-items: stretch; }
[data-figma-id="25:14606"] .industries-grid__row { height: 424px; }
[data-figma-id="25:14606"] .industries-grid__col { gap: 32px; }
[data-figma-id="25:14606"] .industry-card-small { padding: 24px; }
[data-figma-id="25:14606"] .industry-card-big { background: var(--white); }
[data-figma-id="25:14606"] .industry-card-big__image { height: 360px; }
[data-figma-id="25:14606"] .industry-card-big__content { background: var(--white); padding: 48px; gap: 32px; flex: 1; }
[data-figma-id="25:14606"] .industry-card-big__title { font-size: 42px; line-height: 1.1; }

/* G-SENSE MES — Layout/367 patch: results-mixed buttons row spacing + image at bottom of left card */
.results-mixed__actions { display: flex; gap: 24px; align-items: center; flex-wrap: wrap; }
.results-mixed__main { background: var(--gray-bg); }
.results-mixed__main-content { padding: 48px; gap: 32px; }
.results-mixed__card { padding: 48px; gap: 24px; min-height: 383px; }
.industry-card-big__btn-secondary { display: inline-flex; align-items: center; gap: 8px; }

/* Section 5 (Pieniądze w kieszeni / Layout/367) explicit overrides */
[data-figma-id="25:14676"] .results-mixed { align-items: stretch; }
[data-figma-id="25:14676"] .results-mixed__main {
  display: flex; flex-direction: column;
  align-self: stretch;
}
[data-figma-id="25:14676"] .results-mixed__main-content { flex: 1; justify-content: space-between; padding: 48px; }
[data-figma-id="25:14676"] .results-mixed__image { height: 360px; flex-shrink: 0; }
[data-figma-id="25:14676"] .results-mixed__side { display: flex; flex-direction: column; gap: 32px; flex: 1 0 0; min-width: 0; align-self: stretch; }
[data-figma-id="25:14676"] .results-mixed__card { background: var(--gray-bg); flex: 1 0 0; }
[data-figma-id="25:14676"] .results-mixed__card:first-child { flex: 0 1 auto; min-height: 383px; }
[data-figma-id="25:14676"] .results-mixed__card:last-child { flex: 1 1 auto; min-height: 438px; }
[data-figma-id="25:14676"] .results-mixed__heading { font-size: 42px; line-height: 1.1; }

/* Section 1 (Lekki) responsive heading scale-down */

@media (max-width: 1100px) {
  .lekki-section__row { flex-direction: column; gap: 48px; }
  .lekki-section__heading { font-size: 48px; }
}
@media (max-width: 768px) {
  .lekki-section__heading { font-size: 36px; }
  .lekki-section__media { aspect-ratio: 4 / 3; }
}

/* Smartcool ROI + Solution hero (post-audit fix 2026-05-13) */
.solution-hero-image { width: 100%; aspect-ratio: 1200/400; border-radius: var(--radius-lg); object-fit: cover; display: block; }
.roi-three-cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; width: 100%; }
.roi-col { display: flex; flex-direction: column; gap: 24px; align-items: center; text-align: center; padding: 32px; }
.roi-col__icon { width: 96px; height: 96px; flex-shrink: 0; }
.roi-col__icon img { width: 100%; height: 100%; display: block; }
.roi-col__content { display: flex; flex-direction: column; gap: 16px; align-items: center; }
.oee-product-card__text { font-family: var(--font-body); font-size: var(--fs-t2); line-height: normal; color: var(--dark); margin: 0; }

/* ===== Pixel-perfect audit overrides 2026-05-13 (round 4) ===== */

/* hvac-r 25:8315 — Gdzie uciekają — Figma: #666 dark gray cards (audit P2) */
[data-figma-id="25:8315"] .green-card { background: var(--gray-mid2); }

/* optymalizacja-kopaln 25:8812 — Co generuje straty — Figma: WHITE cards with dark text (audit P2) */
[data-figma-id="25:8812"] .green-card {
  background: var(--white);
  border: 1px solid var(--gray-bg);
  color: var(--dark);
}
[data-figma-id="25:8812"] .green-card__title,
[data-figma-id="25:8812"] .green-card__desc,
[data-figma-id="25:8812"] .green-card__link { color: var(--dark); }
[data-figma-id="25:8812"] .green-card__link svg path { stroke: var(--dark); }

/* dyrektor-produkcji 25:16836 — Wyzwania — Figma: #b4b3b5 light gray cards with dark text (audit P2) */
[data-figma-id="25:16836"] .green-card {
  background: #b4b3b5;
  color: var(--dark);
}
[data-figma-id="25:16836"] .green-card__title,
[data-figma-id="25:16836"] .green-card__desc,
[data-figma-id="25:16836"] .green-card__link { color: var(--dark); }
[data-figma-id="25:16836"] .green-card__link svg path { stroke: var(--dark); }
[data-figma-id="25:16836"] .green-card__icon svg path,
[data-figma-id="25:16836"] .green-card__icon svg rect,
[data-figma-id="25:16836"] .green-card__icon svg circle { stroke: var(--dark); }

/* cfo 25:16521 — Problemy — Figma: all 3 cards dark gray, middle has solid green tag (no green bg) (audit P2) */
[data-figma-id="25:16521"] .result-card--featured { background: var(--gray-mid2); }
[data-figma-id="25:16521"] .result-card--featured .tag {
  background: var(--green) !important;
  color: var(--white) !important;
}

/* Hero homepage (25:10780) — Figma overlay is lighter to keep dashboard image visible (audit P2) */
[data-figma-id="25:10780"] .hero__overlay { background: rgba(0,0,0,0.35); }

/* Micronics 25:14993 — 4 bordered cards (Figma: green border, centered, green title) (audit P1) */
.icon-column--bordered {
  border: 1px solid var(--green);
  border-radius: var(--radius-md);
  padding: 24px;
  text-align: center;
  align-items: center;
  justify-content: space-between;
  height: 380px;
  background: var(--white);
}
.icon-column--bordered .icon-column__title { color: var(--green); text-align: center; }
.icon-column--bordered .icon-column__desc { color: var(--dark); text-align: center; }

/* kalkulator 25:10613 — Hero — Figma: green bg with white text (audit P1) */
[data-figma-id="25:10613"] { background: var(--green); }
[data-figma-id="25:10613"] .page-header__title,
[data-figma-id="25:10613"] .page-header__desc { color: var(--white); }

/* dyrektor-produkcji 25:16884 — Rozwiązania dla Twojego działu — Figma: white bordered cards with green icons, dark titles (audit P2) */
[data-figma-id="25:16884"] .persona-tool-col {
  background: var(--white);
  border: 1px solid var(--green);
  border-radius: var(--radius-md);
  padding: 32px 24px;
  align-items: flex-start;
  text-align: left;
}
[data-figma-id="25:16884"] .persona-tool-col__icon { width: 72px; height: 72px; }
[data-figma-id="25:16884"] .persona-tool-col__title { color: var(--dark); font-size: var(--fs-h3-5); font-weight: 800; }
[data-figma-id="25:16884"] .persona-tool-col__desc { font-size: var(--fs-t2); }
[data-figma-id="25:16884"] .persona-tool-col .green-card__link { color: var(--dark) !important; }
[data-figma-id="25:16884"] .persona-tool-col .green-card__link svg path { stroke: var(--dark); }
