@charset "UTF-8";

/* ======================================================================
   KotMaurycy.pl — Homepage Styles (2025)
   Clean, Apple-like layout with spacious typography and subtle motion
   ====================================================================== */

/* Root helpers (reuse variables from base.css) */

/* Smooth transition from hero to next section */
.km-how {
  background: linear-gradient(180deg, #F8FAFC 0%, #FFFFFF 50%);
  position: relative;
}

.km-hero-home {
  position: relative;
  background: 
    radial-gradient(1400px 700px at 75% -15%, rgba(59,130,246,0.035), transparent 65%),
    radial-gradient(900px 500px at 25% 100%, rgba(245,158,11,0.025), transparent 60%),
    linear-gradient(180deg, #FEFEFE 0%, #FFFFFF 40%, #FAFBFC 100%);
  overflow: hidden;
}

/* Subtelny szum/grain dla premium feel */
.km-hero-home::before {
  content: "";
  position: absolute; 
  inset: 0;
  background-image: 
    radial-gradient(circle at 20% 15%, rgba(11,37,69,0.02) 0%, transparent 50%),
    radial-gradient(circle at 80% 80%, rgba(59,130,246,0.015) 0%, transparent 45%),
    url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='0.015'/%3E%3C/svg%3E");
  pointer-events: none;
  opacity: 0.8;
}

.km-hero-home { padding-top: calc(80px + var(--km-space-sm)); padding-bottom: var(--km-space-sm); }

.km-hero-grid { display: grid; grid-template-columns: 1.15fr 0.85fr; grid-template-areas: 'copy media' 'sub media' 'cta media'; gap: var(--km-space-xl); align-items: center; min-height: auto; }
.km-hero-copy { grid-area: copy; }
.km-hero-sub-wrap { grid-area: sub; }
.km-hero-media { grid-area: media; }
.km-hero-cta { grid-area: cta; }

/* Premium badge */
.km-hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.4rem 0.85rem 0.4rem 0.75rem;
  background: linear-gradient(135deg, rgba(245, 158, 11, 0.08) 0%, rgba(59, 130, 246, 0.06) 100%);
  border: 1px solid rgba(245, 158, 11, 0.2);
  border-radius: var(--km-radius-full);
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--km-gray-700);
  letter-spacing: -0.003em;
  margin-bottom: var(--km-space-md);
  box-shadow: 0 2px 8px rgba(245, 158, 11, 0.08);
  backdrop-filter: blur(4px);
  animation: badge-float 3s ease-in-out infinite;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  cursor: default;
  user-select: none;
}

.km-hero-badge:hover {
  background: linear-gradient(135deg, rgba(245, 158, 11, 0.12) 0%, rgba(59, 130, 246, 0.09) 100%);
  border-color: rgba(245, 158, 11, 0.3);
  box-shadow: 0 4px 12px rgba(245, 158, 11, 0.12);
  transform: translateY(-1px);
}

.km-hero-badge svg {
  color: var(--km-orange);
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.km-hero-badge:hover svg {
  transform: rotate(12deg) scale(1.1);
}

@keyframes badge-float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-3px); }
}
.km-hero-title { 
  font-size: clamp(2.2rem, 3.2vw + 1rem, 3.75rem); 
  line-height: 1.08; 
  margin-bottom: var(--km-space-md); 
  letter-spacing: -0.025em; 
  max-width: 22ch;
  font-weight: 800;
  color: var(--km-navy);
  text-shadow: 0 1px 2px rgba(2,6,23,0.04);
}
.km-hero-sub { 
  font-size: 1.1875rem; 
  color: var(--km-gray-600); 
  max-width: 44ch; 
  line-height: 1.65;
  letter-spacing: -0.005em;
  font-weight: 450;
}
.km-hero-cta { margin-top: var(--km-space-lg); display: flex; gap: var(--km-space-sm); align-items: flex-start; flex-wrap: wrap; flex-direction: column; text-align: left; }
.km-hero-cta-note { 
  color: var(--km-gray-600); 
  font-size: 1rem; 
  margin: 0; 
  font-weight: 550;
  letter-spacing: -0.005em;
}
.km-highlight { 
  background: linear-gradient(transparent calc(100% - var(--km-highlight-thickness)), rgba(245,158,11,.42) calc(100% - var(--km-highlight-thickness))); 
  box-decoration-break: clone; 
  padding-bottom: calc(var(--km-highlight-offset));
  font-weight: 800;
  position: relative;
  display: inline-block;
}
/* Subtelny glow efekt dla highlight */
.km-highlight::before {
  content: '';
  position: absolute;
  inset: -3px;
  background: radial-gradient(ellipse at center, rgba(245,158,11,0.08) 0%, transparent 70%);
  z-index: -1;
  opacity: 0;
  transition: opacity 0.4s ease;
}
.km-hero-copy:hover .km-highlight::before {
  opacity: 1;
}

.km-hero-kitty { 
  width: min(500px, 92%); 
  height: auto; 
  display: block; 
  margin: 0 auto; 
  filter: 
    drop-shadow(0 20px 40px rgba(2,6,23,0.08))
    drop-shadow(0 8px 16px rgba(2,6,23,0.06))
    drop-shadow(0 2px 4px rgba(2,6,23,0.04));
  animation: gentle-float 9s ease-in-out infinite;
  transform-origin: center;
  will-change: transform;
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1), filter 0.4s ease;
}

.km-hero-media:hover .km-hero-kitty {
  filter: 
    drop-shadow(0 24px 48px rgba(2,6,23,0.10))
    drop-shadow(0 12px 24px rgba(2,6,23,0.08))
    drop-shadow(0 4px 8px rgba(2,6,23,0.06));
}

/* Ulepszona animacja float */
@keyframes gentle-float {
  0%, 100% { 
    transform: translateY(0) scale(1);
  }
  25% {
    transform: translateY(-8px) scale(1.005);
  }
  50% { 
    transform: translateY(0) scale(1);
  }
  75% {
    transform: translateY(-4px) scale(0.998);
  }
}

@media (max-width: 980px) {
  .km-hero-home { padding-top: calc(80px + var(--km-space-md)); }
  .km-hero-grid {
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
      'copy copy'
      'sub media'
      'cta cta';
    column-gap: var(--km-space-lg);
    row-gap: var(--km-space-md);
    align-items: center;
  }
  .km-hero-sub { margin: 0; text-align: left; }
  .km-hero-cta { justify-content: center; align-items: center; text-align: center; }
  .km-hero-media { display: flex; justify-content: center; }
  .km-hero-title { font-size: clamp(2rem, 4vw + 0.8rem, 3.2rem); }
  .km-hero-sub { font-size: 1.0625rem; }
}

/* Compact single-column layout on smaller devices; CTA above image */
@media (max-width: 820px) {
  .km-hero-grid {
    grid-template-columns: 1fr;
    grid-template-areas:
      'copy'
      'sub'
      'cta'
      'media';
    row-gap: var(--km-space-md);
  }
  .km-hero-cta { margin-top: var(--km-space-sm); align-items: stretch; text-align: left; }
  .km-hero-kitty { width: min(70vw, 340px); }
  .km-hero-title { font-size: clamp(1.85rem, 4.5vw + 0.7rem, 2.5rem); }
  .km-hero-sub { font-size: 1.0625rem; }
}

/* Ensure hero fits initial viewport without cropping on modern browsers */
@supports (height: 100dvh) {
  .km-hero-home { min-height: auto; }
  .km-hero-grid {
    min-height: calc(100dvh - 80px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px) - (2 * var(--km-space-sm)));
  }
}

/* Fallback for browsers without dynamic viewport units */
@supports not (height: 100dvh) {
  .km-hero-home { min-height: auto; }
  .km-hero-grid { min-height: calc(100vh - 80px - (2 * var(--km-space-sm))); }
}

/* Small height screens (e.g., 13" laptops, landscape phones) */
@media (max-height: 780px) and (min-width: 981px) {
  .km-hero-title { font-size: clamp(2rem, 2.4vw + 1rem, 3.2rem); }
  .km-hero-sub { font-size: 1.125rem; }
  .km-hero-kitty { width: min(420px, 85%); }
  .km-hero-cta { margin-top: var(--km-space-lg); }
}

/* Very small height (e.g., 720p or docked browser) */
@media (max-height: 680px) and (min-width: 981px) {
  .km-hero-title { font-size: clamp(1.8rem, 2.1vw + 1rem, 2.8rem); }
  .km-hero-sub { font-size: 1.05rem; }
  .km-hero-kitty { width: min(380px, 80%); }
}

/* Mobile-first tuning */
@media (max-width: 640px) {
  .km-hero-title { font-size: clamp(1.6rem, 5.2vw + 0.7rem, 2.05rem); line-height: 1.08; max-width: 24ch; }
  .km-hero-sub { font-size: 1rem; max-width: 48ch; }
  .km-hero-kitty { width: min(62vw, 320px); }
  .km-hero-cta { gap: 10px; margin-top: var(--km-space-sm); }
  .km-hero-badge { 
    font-size: 0.75rem; 
    padding: 0.35rem 0.75rem 0.35rem 0.65rem; 
    margin-bottom: var(--km-space-sm);
  }
  .km-hero-badge svg { 
    width: 12px; 
    height: 12px; 
  }
}

/* Claim */
.km-claim { background: linear-gradient(180deg, #fff, var(--km-gray-50)); }
.km-claim-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--km-space-xl); }
.km-claim-card { 
  background: var(--km-white); 
  border: 1px solid var(--km-gray-200); 
  border-radius: var(--km-radius-xl); 
  padding: var(--km-space-xl); 
  box-shadow: 
    0 1px 3px rgba(11, 37, 69, 0.06),
    0 8px 16px rgba(11, 37, 69, 0.04);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.km-claim-card:hover {
  box-shadow: 
    0 2px 6px rgba(11, 37, 69, 0.08),
    0 12px 24px rgba(11, 37, 69, 0.06);
  transform: translateY(-2px);
}
@media (max-width: 900px) { .km-claim-grid { grid-template-columns: 1fr; } }

/* ========================================
   SIMPLIFIED: HOW IT WORKS SECTION
   ======================================== */

/* Section background with subtle gradient */
.km-how-simplified {
  background:
    radial-gradient(ellipse 1200px 600px at 50% 0%, rgba(245, 158, 11, 0.03) 0%, transparent 50%),
    radial-gradient(ellipse 800px 400px at 50% 100%, rgba(59, 130, 246, 0.02) 0%, transparent 60%),
    linear-gradient(180deg, #FFFFFF 0%, #FEFEFE 50%, #FAFBFC 100%);
  position: relative;
  padding: calc(var(--km-space-xl) + var(--km-space-lg)) 0;
}

.km-how-simplified::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='0.008'/%3E%3C/svg%3E");
  pointer-events: none;
}

/* Główny nagłówek */
.km-how-header {
  text-align: center;
  margin-bottom: var(--km-space-2xl);
}

.km-how-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  background: linear-gradient(135deg, rgba(245, 158, 11, 0.08) 0%, rgba(59, 130, 246, 0.06) 100%);
  border: 1px solid rgba(245, 158, 11, 0.2);
  border-radius: var(--km-radius-full);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--km-gray-700);
  letter-spacing: -0.003em;
  margin-bottom: var(--km-space-lg);
  box-shadow: 0 2px 8px rgba(245, 158, 11, 0.08);
  backdrop-filter: blur(4px);
}

.km-how-title {
  font-size: clamp(2.5rem, 3.5vw + 1rem, 4rem);
  font-weight: 800;
  color: var(--km-navy);
  line-height: 1.1;
  margin-bottom: var(--km-space-lg);
  letter-spacing: -0.025em;
}

.km-how-subtitle {
  font-size: clamp(1.125rem, 1.5vw + 0.5rem, 1.375rem);
  color: var(--km-gray-600);
  max-width: 60ch;
  margin: 0 auto;
  line-height: 1.6;
  font-weight: 450;
}

/* Intro grid with visual next to copy (under header) */
.km-how-intro-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: var(--km-space-xl);
  align-items: center;
  max-width: 1100px;
  margin: 0 auto;
}

.km-how-intro-copy {
  text-align: left;
}

.km-how-intro-visual {
  margin: 0;
}

.km-how-intro-image-wrap {
  position: relative;
  width: 100%;
  max-width: 520px;
  margin: 0 auto;
  aspect-ratio: 4 / 3;
  display: grid;
  place-items: center;
}

.km-how-intro-image-wrap::before {
  content: "";
  position: absolute;
  inset: -8%;
  background: radial-gradient(ellipse at center, rgba(245,158,11,0.10) 0%, rgba(59,130,246,0.06) 40%, transparent 70%);
  filter: blur(36px);
  border-radius: 28px;
  z-index: 0;
}

.km-how-intro-image {
  position: relative;
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--km-radius-xl);
  border: 1px solid var(--km-gray-200);
  box-shadow:
    0 2px 8px rgba(11, 37, 69, 0.06),
    0 18px 36px rgba(11, 37, 69, 0.08);
}

@media (max-width: 1024px) {
  .km-how-intro-grid {
    grid-template-columns: 1fr;
    gap: var(--km-space-lg);
  }
  .km-how-header { text-align: left; }
  .km-how-subtitle { margin-left: 0; margin-right: 0; }
  .km-how-intro-image-wrap { max-width: 560px; }
}

@media (max-width: 640px) {
  .km-how-intro-image-wrap { max-width: 100%; aspect-ratio: auto; }
  .km-how-intro-image { border-radius: var(--km-radius-lg); }
}

/* Trzy kafelki z korzyściami */
.km-benefits-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--km-space-md);
  margin-bottom: var(--km-space-xl);
}

.km-benefit-card {
  background: var(--km-white);
  border: 1px solid var(--km-gray-200);
  border-radius: var(--km-radius-xl);
  padding: var(--km-space-xl);
  text-align: center;
  box-shadow:
    0 2px 8px rgba(11, 37, 69, 0.06),
    0 12px 24px rgba(11, 37, 69, 0.04);
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
}

.km-benefit-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(245, 158, 11, 0.02) 0%, rgba(59, 130, 246, 0.02) 100%);
  opacity: 0;
  transition: opacity 0.4s ease;
}

.km-benefit-card:hover {
  box-shadow:
    0 4px 16px rgba(11, 37, 69, 0.08),
    0 20px 40px rgba(11, 37, 69, 0.06);
  transform: translateY(-4px);
  border-color: rgba(245, 158, 11, 0.2);
}

.km-benefit-card:hover::before {
  opacity: 1;
}

.km-benefit-card--companies:hover {
  background: linear-gradient(135deg, rgba(34, 197, 94, 0.02) 0%, rgba(245, 158, 11, 0.02) 100%);
}

.km-benefit-card--students:hover {
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.02) 0%, rgba(168, 85, 247, 0.02) 100%);
}

.km-benefit-card--world:hover {
  background: linear-gradient(135deg, rgba(168, 85, 247, 0.02) 0%, rgba(239, 68, 68, 0.02) 100%);
}

/* Benefit: switch from simple icon to a photo presentation */
.km-benefit-media {
  width: 100%;
  max-width: 220px;
  margin: 0 auto var(--km-space-lg) auto;
  border-radius: var(--km-radius-xl);
  overflow: hidden;
  border: 1px solid var(--km-gray-200);
  box-shadow:
    0 2px 8px rgba(11, 37, 69, 0.06),
    0 12px 24px rgba(11, 37, 69, 0.04);
  background: var(--km-white);
}

.km-benefit-image {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
  aspect-ratio: 1 / 1;
  transform: translateZ(0);
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.km-benefit-card:hover .km-benefit-image {
  transform: scale(1.03);
}

.km-benefit-title {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--km-navy);
  margin-bottom: var(--km-space-md);
  line-height: 1.2;
}

.km-benefit-text {
  color: var(--km-gray-600);
  line-height: 1.6;
  font-size: 1rem;
  font-weight: 450;
}

/* Prosty proces w trzech krokach */
.km-process-simple {
  margin-bottom: var(--km-space-xl);
}

.km-process-title {
  font-size: clamp(1.875rem, 2.2vw + 1rem, 2.25rem);
  font-weight: 700;
  color: var(--km-navy);
  text-align: center;
  margin-bottom: var(--km-space-lg);
  line-height: 1.2;
}

.km-process-steps {
  display: flex;
  flex-direction: column;
  gap: var(--km-space-lg);
  max-width: 900px;
  margin: 0 auto;
}

.km-process-step {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: var(--km-space-md);
  align-items: start;
  padding: var(--km-space-md);
  background: var(--km-white);
  border: 1px solid var(--km-gray-200);
  border-radius: var(--km-radius-xl);
  box-shadow:
    0 2px 8px rgba(11, 37, 69, 0.06),
    0 12px 24px rgba(11, 37, 69, 0.04);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
}

.km-process-step:hover {
  box-shadow:
    0 4px 16px rgba(11, 37, 69, 0.08),
    0 20px 40px rgba(11, 37, 69, 0.06);
  transform: translateY(-2px);
  border-color: rgba(59, 130, 246, 0.2);
}

.km-process-number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  background: linear-gradient(135deg, var(--km-blue) 0%, #3b82f6 100%);
  color: white;
  border-radius: 50%;
  font-size: 1.25rem;
  font-weight: 800;
  box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3);
  flex-shrink: 0;
}

.km-process-content {
  padding-top: var(--km-space-xs);
}

.km-process-step-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--km-navy);
  margin-bottom: var(--km-space-sm);
  line-height: 1.3;
}

.km-process-step-text {
  color: var(--km-gray-600);
  font-size: 1rem;
  line-height: 1.6;
  font-weight: 450;
  margin: 0;
}

/* CTA Section */
.km-how-cta-simple {
  text-align: center;
}

.km-how-cta-content {
  background: linear-gradient(135deg, var(--km-navy) 0%, #0f172a 100%);
  border-radius: var(--km-radius-2xl);
  padding: var(--km-space-xl);
  color: white;
  box-shadow:
    0 8px 24px rgba(15, 23, 42, 0.15),
    0 20px 48px rgba(15, 23, 42, 0.1);
  max-width: 800px;
  margin: 0 auto;
}

.km-how-cta-simple h3 {
  font-size: clamp(1.5rem, 2vw + 0.5rem, 2rem);
  font-weight: 700;
  margin-bottom: var(--km-space-sm);
  color: #fff;
  line-height: 1.3;
}

.km-how-cta-simple p {
  font-size: 1.125rem;
  margin-bottom: var(--km-space-lg);
  opacity: 0.9;
  max-width: 50ch;
  margin-left: auto;
  margin-right: auto;
}

/* Responsive Design dla nowej sekcji */
@media (max-width: 768px) {
  .km-how-simplified {
    padding: var(--km-space-xl) 0;
  }

  .km-process-step {
    grid-template-columns: 60px 1fr;
    gap: var(--km-space-md);
    padding: var(--km-space-md);
  }

  .km-process-number {
    width: 48px;
    height: 48px;
    font-size: 1.125rem;
  }

  .km-process-step-title {
    font-size: 1.125rem;
  }

  .km-process-step-text {
    font-size: 0.9375rem;
  }

  .km-benefits-grid {
    grid-template-columns: 1fr;
    gap: var(--km-space-md);
  }

  .km-benefit-card {
    padding: var(--km-space-lg);
  }

  .km-benefit-icon {
    width: 100%;
    height: auto;
  }

  .km-benefit-title {
    font-size: 1.25rem;
  }

  .km-benefit-text {
    font-size: 0.9375rem;
  }

  .km-how-title {
    font-size: clamp(2rem, 4vw + 1rem, 3rem);
  }

  .km-how-subtitle {
    font-size: 1rem;
  }
}

@media (max-width: 640px) {
  .km-process-step {
    grid-template-columns: 1fr;
    gap: var(--km-space-sm);
    text-align: center;
  }

  .km-process-number {
    justify-self: center;
    margin-bottom: var(--km-space-sm);
  }

  .km-benefit-card {
    padding: var(--km-space-md);
  }

  .km-how-cta-content {
    padding: var(--km-space-xl);
  }
}

/* Why it works — lead line */
.km-why-lead {
  margin: 0 0 var(--km-space-sm) 0;
  color: var(--km-navy);
  font-weight: 700;
  letter-spacing: -0.01em;
}

/* Project example preview (figure) */
.km-project-preview {
  margin: var(--km-space-sm) 0 var(--km-space-sm);
  border-radius: var(--km-radius-xl);
  overflow: hidden;
  border: 1px solid var(--km-gray-200);
  box-shadow: 
    0 1px 3px rgba(11, 37, 69, 0.06),
    0 10px 24px rgba(11, 37, 69, 0.06);
  background: var(--km-white);
}
.km-project-preview img {
  display: block;
  width: 100%;
  height: auto;
  transform: translateZ(0);
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.km-project-preview:hover img {
  transform: scale(1.01);
}
.km-project-caption {
  margin: 0;
  padding: 0.6rem 0.9rem;
  font-size: 0.95rem;
  color: var(--km-gray-700);
  background: rgba(15, 23, 42, 0.03);
  border-top: 1px solid var(--km-gray-100);
  text-align: center;
}

/* ======================================================
   CASE STUDY / SHOWCASE SECTION (Students' work example)
   ====================================================== */
.km-showcase-section {
  background:
    radial-gradient(ellipse 1200px 600px at 50% 0%, rgba(59, 130, 246, 0.04) 0%, transparent 50%),
    radial-gradient(ellipse 800px 400px at 50% 100%, rgba(245, 158, 11, 0.03) 0%, transparent 60%),
    linear-gradient(180deg, #FFFFFF 0%, #FEFEFE 50%, #FAFBFC 100%);
  position: relative;
  padding: calc(var(--km-space-2xl) + var(--km-space-xl)) 0;
}

.km-showcase-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='0.008'/%3E%3C/svg%3E");
  pointer-events: none;
}

.km-showcase-card {
  background: var(--km-white);
  border: 1px solid var(--km-gray-200);
  border-radius: var(--km-radius-2xl);
  padding: var(--km-space-2xl);
  box-shadow:
    0 2px 8px rgba(11, 37, 69, 0.06),
    0 24px 48px rgba(11, 37, 69, 0.04);
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.km-showcase-card:hover {
  transform: translateY(-4px);
  box-shadow:
    0 6px 16px rgba(11, 37, 69, 0.08),
    0 28px 56px rgba(11, 37, 69, 0.06);
}

.km-showcase-grid {
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: var(--km-space-xl);
  align-items: start;
  margin-top: var(--km-space-xl);
}

.km-showcase-media {
  position: relative;
}

.km-showcase-content {
  display: grid;
  gap: var(--km-space-lg);
}

.km-showcase-title {
  margin: 0;
  color: var(--km-navy);
}

.km-showcase-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--km-space-sm);
}

.km-showcase-list li {
  display: flex;
  align-items: flex-start;
  gap: var(--km-space-sm);
  padding: var(--km-space-sm) var(--km-space-md);
  background: rgba(59, 130, 246, 0.05);
  border-radius: var(--km-radius-lg);
  border: 1px solid rgba(59, 130, 246, 0.12);
  color: var(--km-gray-700);
}

.km-showcase-list li::before {
  content: "✔";
  color: var(--km-blue);
  font-weight: 800;
  line-height: 1.4;
}

.km-showcase-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--km-space-md);
}

.km-showcase-stat {
  text-align: center;
  padding: var(--km-space-md);
  background: linear-gradient(135deg, rgba(245, 158, 11, 0.08), rgba(59, 130, 246, 0.06));
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: var(--km-radius-xl);
}

.km-showcase-stat span {
  display: block;
  font-size: 1.125rem;
  font-weight: 800;
  color: var(--km-navy);
}

.km-showcase-stat small {
  color: var(--km-gray-600);
}

.km-showcase-cta {
  display: flex;
  gap: var(--km-space-sm);
  flex-wrap: wrap;
}

.km-showcase-note {
  color: var(--km-gray-500);
  font-size: 0.9375rem;
  margin: 0;
}

@media (max-width: 980px) {
  .km-showcase-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .km-showcase-card {
    padding: var(--km-space-xl);
  }
  .km-showcase-stats {
    grid-template-columns: 1fr;
  }
  .km-showcase-cta {
    flex-direction: column;
  }
}

/* Steps */
.km-steps-list { counter-reset: step; list-style: none; padding: 0; display: grid; gap: var(--km-space-md); max-width: 900px; margin: 0 auto; }
.km-steps-list li { 
  position: relative; 
  padding: var(--km-space-md) var(--km-space-lg) var(--km-space-md) calc(var(--km-space-lg) + 36px); 
  border: 1px solid var(--km-gray-200); 
  border-radius: var(--km-radius-xl); 
  background: var(--km-white); 
  box-shadow: 
    0 1px 3px rgba(11, 37, 69, 0.06),
    0 6px 12px rgba(11, 37, 69, 0.03);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.km-steps-list li:hover {
  box-shadow: 
    0 2px 6px rgba(11, 37, 69, 0.08),
    0 10px 20px rgba(11, 37, 69, 0.05);
  transform: translateX(4px);
}
.km-steps-list li::before { 
  counter-increment: step; 
  content: counter(step); 
  position: absolute; 
  left: var(--km-space-lg); 
  top: 50%; 
  transform: translateY(-50%); 
  width: 28px; 
  height: 28px; 
  border-radius: 999px; 
  background: var(--km-gradient-orange); 
  color: #fff; 
  display: grid; 
  place-items: center; 
  font-weight: 800; 
  box-shadow: 
    0 2px 6px rgba(245, 158, 11, 0.3),
    0 6px 12px rgba(11, 37, 69, 0.1);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.km-steps-list li:hover::before {
  transform: translateY(-50%) scale(1.1);
  box-shadow: 
    0 3px 9px rgba(245, 158, 11, 0.4),
    0 8px 16px rgba(11, 37, 69, 0.15);
}
.km-steps-cta { text-align: center; margin-top: var(--km-space-xl); }

/* Course */
.km-course-grid { display: grid; grid-template-columns: 1fr; gap: var(--km-space-xl); }
.km-course-card { 
  background: var(--km-white); 
  border: 1px solid var(--km-gray-200); 
  border-radius: var(--km-radius-xl); 
  padding: var(--km-space-xl); 
  box-shadow: 
    0 1px 3px rgba(11, 37, 69, 0.06),
    0 8px 16px rgba(11, 37, 69, 0.04);
  max-width: 900px; 
  margin: 0 auto;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.km-course-card:hover {
  box-shadow: 
    0 2px 6px rgba(11, 37, 69, 0.08),
    0 12px 24px rgba(11, 37, 69, 0.06);
  transform: translateY(-2px);
}
.km-course-claim { margin-top: var(--km-space-sm); font-weight: 600; color: var(--km-gray-700); }
.km-course-cta { display: flex; gap: var(--km-space-sm); margin-top: var(--km-space-md); flex-wrap: wrap; justify-content: center; }
.km-course-cta .km-btn { flex: 0 0 auto; }

/* Final CTA */
.km-final { background: linear-gradient(180deg, var(--km-gray-50), #fff); }
.km-final-card {
  background: var(--km-white);
  border: 1px solid var(--km-gray-200);
  border-radius: var(--km-radius-2xl);
  padding: var(--km-space-2xl);
  box-shadow:
    0 2px 6px rgba(11, 37, 69, 0.08),
    0 16px 32px rgba(11, 37, 69, 0.06);
  text-align: center;
  max-width: 1000px;
  margin: 0 auto;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.km-final-card:hover {
  box-shadow:
    0 3px 9px rgba(11, 37, 69, 0.1),
    0 20px 40px rgba(11, 37, 69, 0.08);
  transform: translateY(-2px);
}

.km-final-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  background: linear-gradient(135deg, rgba(34, 197, 94, 0.08) 0%, rgba(59, 130, 246, 0.06) 100%);
  border: 1px solid rgba(34, 197, 94, 0.2);
  border-radius: var(--km-radius-full);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--km-gray-700);
  letter-spacing: -0.003em;
  margin-bottom: var(--km-space-lg);
  box-shadow: 0 2px 8px rgba(34, 197, 94, 0.08);
  backdrop-filter: blur(4px);
}

.km-final-cta { margin-top: var(--km-space-xl); }

/* Final CTA embedded form cohesion */
#final-cta .km-final-card {
  padding-bottom: calc(var(--km-space-xl) + 8px);
}
#final-cta .km-cta-form {
  max-width: 720px;
  margin: var(--km-space-md) auto 0 auto;
}
#final-cta .km-cta-success {
  max-width: 720px;
  margin: var(--km-space-md) auto 0 auto;
}
#final-cta .km-cta-steps { justify-content: center; }

/* CTA Modal */
.km-cta-section { position: relative; }
.km-cta-modal { position: fixed; inset: 0; display: none; place-items: center; background: rgba(2,6,23,0.55); backdrop-filter: blur(4px); z-index: 1000; padding: var(--km-space-sm); }
.km-cta-modal.show { display: grid; animation: fadeIn 0.25s ease-out; }
.km-cta-card { width: min(720px, 100%); background: #fff; border: 1px solid var(--km-gray-200); border-radius: var(--km-radius-2xl); box-shadow: var(--km-shadow-2xl); padding: var(--km-space-xl); position: relative; }
.km-cta-close { position: absolute; top: 16px; right: 16px; border: 0; background: transparent; color: var(--km-gray-500); font-size: 1.25rem; cursor: pointer; }
.km-cta-title { margin-bottom: var(--km-space-sm); }
.km-cta-lead { color: var(--km-gray-600); margin-bottom: var(--km-space-md); }
.km-cta-form { display: grid; gap: var(--km-space-sm); }
.km-cta-status { min-height: 1.25rem; font-size: 0.95rem; }
.km-cta-status.is-error { color: #b91c1c; }
.km-cta-status.is-success { color: #166534; }
.km-cta-success { display: none; }
.km-cta-success.show { display: block; }
.km-cta-success-inner { text-align: center; padding: var(--km-space-lg); }
.km-cta-success-icon { font-size: 2.25rem; }
.km-cta-steps { display: flex; gap: 6px; margin-bottom: var(--km-space-sm); }
.km-cta-step { width: 22px; height: 22px; border-radius: 999px; background: var(--km-gray-200); color: var(--km-gray-700); display: grid; place-items: center; font-weight: 700; font-size: 0.8rem; opacity: .8; }
.km-cta-step.active { background: var(--km-orange); color: #fff; opacity: 1; }

/* Floating labels */
.km-floating { position: relative; display: grid; }
.km-floating > span { position: absolute; left: 12px; top: 12px; color: var(--km-gray-500); background: #fff; padding: 0 6px; pointer-events: none; transform-origin: left top; transition: var(--km-transition-fast); }
.km-cta-floating-input, .km-cta-floating-textarea { width: 100%; border: 1px solid var(--km-gray-300); border-radius: var(--km-radius-lg); padding: 14px 14px; font: inherit; outline: none; transition: var(--km-transition-fast); }
.km-cta-floating-input:focus, .km-cta-floating-textarea:focus { border-color: var(--km-blue); box-shadow: 0 0 0 4px rgba(59,130,246,0.12); }
.km-cta-floating-input[data-has-value] ~ span,
.km-cta-floating-textarea[data-has-value] ~ span,
.km-cta-floating-input:focus ~ span,
.km-cta-floating-textarea:focus ~ span { transform: translateY(-20px) scale(.85); color: var(--km-blue); }

/* Floating labels for /dolacz application form fields */
.km-form-input:focus + span,
.km-form-input:not(:placeholder-shown) + span,
.km-form-textarea:focus + span,
.km-form-textarea:not(:placeholder-shown) + span {
  transform: translateY(-20px) scale(.85);
  color: var(--km-blue);
}

/* Ensure autofilled fields also float labels (WebKit) */
.km-form-input:-webkit-autofill + span,
.km-form-textarea:-webkit-autofill + span {
  transform: translateY(-20px) scale(.85);
  color: var(--km-blue);
}

/* Premium button styling for hero CTA */
.km-hero-cta .km-btn-primary {
  font-size: 1.0625rem;
  padding: 0.875rem 2rem;
  box-shadow: 
    0 1px 2px rgba(245, 158, 11, 0.4),
    0 4px 12px rgba(245, 158, 11, 0.2),
    0 8px 24px rgba(11, 37, 69, 0.08);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
}

.km-hero-cta .km-btn-primary:hover {
  box-shadow: 
    0 2px 4px rgba(245, 158, 11, 0.5),
    0 8px 20px rgba(245, 158, 11, 0.25),
    0 16px 40px rgba(11, 37, 69, 0.12);
  transform: translateY(-3px);
}

.km-hero-cta .km-btn-primary:active {
  transform: translateY(-1px);
  box-shadow: 
    0 1px 2px rgba(245, 158, 11, 0.4),
    0 4px 12px rgba(245, 158, 11, 0.2);
}

/* Subtle shimmer effect na przycisku */
.km-hero-cta .km-btn-primary::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
  animation: shimmer 3s ease-in-out infinite;
}

@keyframes shimmer {
  0%, 100% { left: -100%; }
  50% { left: 100%; }
}

/* Animations */
@keyframes fadeIn { from { opacity: 0 } to { opacity: 1 } }
@keyframes shake { 10%, 90% { transform: translateX(-1px) } 20%, 80% { transform: translateX(2px) } 30%, 50%, 70% { transform: translateX(-4px) } 40%, 60% { transform: translateX(4px) } }

/* A11y & Focus States */
.km-cta-modal:focus-within .km-cta-card { outline: 3px solid rgba(59,130,246,.3); }

.km-hero-badge:focus-visible,
.km-hero-cta .km-btn:focus-visible {
  outline: 3px solid rgba(245, 158, 11, 0.5);
  outline-offset: 3px;
}

/* ========================================
   NOWE SEKCJE: TEAM & COURSE REDESIGNED
   ======================================== */

/* Sekcja zespołu - social proof i rekrutacja */
.km-team-section {
  background:
    radial-gradient(ellipse 1000px 500px at 50% 0%, rgba(59, 130, 246, 0.04) 0%, transparent 50%),
    radial-gradient(ellipse 800px 400px at 50% 100%, rgba(245, 158, 11, 0.03) 0%, transparent 60%),
    linear-gradient(180deg, #FFFFFF 0%, #FEFEFE 50%, #FAFBFC 100%);
  position: relative;
  padding: calc(var(--km-space-2xl) + var(--km-space-xl)) 0;
}

.km-team-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='0.008'/%3E%3C/svg%3E");
  pointer-events: none;
}

.km-team-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--km-space-xl);
  max-width: 1000px;
  margin: 0 auto;
}

.km-team-card {
  background: var(--km-white);
  border: 1px solid var(--km-gray-200);
  border-radius: var(--km-radius-xl);
  padding: var(--km-space-2xl);
  box-shadow:
    0 2px 8px rgba(11, 37, 69, 0.06),
    0 16px 32px rgba(11, 37, 69, 0.04);
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
}

.km-team-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.02) 0%, rgba(245, 158, 11, 0.02) 100%);
  opacity: 0;
  transition: opacity 0.4s ease;
}

.km-team-card:hover {
  box-shadow:
    0 4px 16px rgba(11, 37, 69, 0.08),
    0 24px 48px rgba(11, 37, 69, 0.06);
  transform: translateY(-4px);
  border-color: rgba(59, 130, 246, 0.2);
}

.km-team-card:hover::before {
  opacity: 1;
}

.km-team-highlight {
  font-size: 1.125rem;
  color: var(--km-gray-700);
  font-weight: 500;
  line-height: 1.7;
  margin-bottom: var(--km-space-xl);
  text-align: center;
  max-width: 70ch;
  margin-left: auto;
  margin-right: auto;
}

.km-team-benefits {
  display: grid;
  gap: var(--km-space-lg);
  margin-bottom: var(--km-space-xl);
}

.km-team-benefit {
  display: flex;
  align-items: flex-start;
  gap: var(--km-space-md);
  padding: var(--km-space-md);
  background: rgba(59, 130, 246, 0.02);
  border-radius: var(--km-radius-lg);
  border: 1px solid rgba(59, 130, 246, 0.1);
  transition: all 0.3s ease;
}

.km-team-benefit:hover {
  background: rgba(59, 130, 246, 0.05);
  transform: translateX(4px);
}

.km-team-benefit-icon {
  font-size: 1.5rem;
  flex-shrink: 0;
}

.km-team-benefit-content h4 {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--km-navy);
  margin-bottom: var(--km-space-xs);
}

.km-team-benefit-content p {
  color: var(--km-gray-600);
  font-size: 0.9375rem;
  line-height: 1.5;
  margin: 0;
}

.km-team-cta {
  text-align: center;
  margin-top: var(--km-space-xl);
}

.km-btn-team {
  background: linear-gradient(135deg, var(--km-blue) 0%, #3b82f6 100%);
  box-shadow:
    0 4px 16px rgba(59, 130, 246, 0.3),
    0 8px 24px rgba(11, 37, 69, 0.1);
  position: relative;
  overflow: hidden;
}

.km-btn-team::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
  animation: team-shine 3s ease-in-out infinite;
}

@keyframes team-shine {
  0%, 100% { left: -100%; }
  50% { left: 100%; }
}

.km-btn-team:hover {
  box-shadow:
    0 6px 20px rgba(59, 130, 246, 0.4),
    0 12px 32px rgba(11, 37, 69, 0.15);
  transform: translateY(-2px);
}

.km-team-note {
  color: var(--km-gray-500);
  font-size: 0.9375rem;
  margin: var(--km-space-sm) 0 0 0;
  font-weight: 500;
}

/* Sekcja kursu - prezent od Kota */
.km-course-section {
  background:
    radial-gradient(ellipse 1200px 600px at 50% 0%, rgba(245, 158, 11, 0.03) 0%, transparent 50%),
    radial-gradient(ellipse 800px 400px at 50% 100%, rgba(34, 197, 94, 0.02) 0%, transparent 60%),
    linear-gradient(180deg, #FAFBFC 0%, #FFFFFF 50%, #FEFEFE 100%);
  position: relative;
  padding: calc(var(--km-space-2xl) + var(--km-space-xl)) 0;
}

.km-course-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='0.008'/%3E%3C/svg%3E");
  pointer-events: none;
}

.km-course-card--gift {
  background: linear-gradient(135deg, var(--km-white) 0%, #fff9f0 100%);
  border: 2px solid rgba(245, 158, 11, 0.2);
  position: relative;
}

.km-course-card--gift::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--km-orange) 0%, #f59e0b 50%, var(--km-orange) 100%);
}

.km-course-intro {
  margin-bottom: var(--km-space-lg);
}

.km-course-description {
  font-size: 1.125rem;
  color: var(--km-gray-700);
  line-height: 1.7;
  text-align: center;
  max-width: 65ch;
  margin: 0 auto;
}

.km-course-content {
  margin-bottom: var(--km-space-lg);
}

.km-course-subtitle {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--km-navy);
  margin-bottom: var(--km-space-md);
  text-align: center;
}

.km-course-features {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--km-space-sm);
}

.km-course-features li {
  display: flex;
  align-items: center;
  gap: var(--km-space-sm);
  padding: var(--km-space-sm) var(--km-space-md);
  background: rgba(245, 158, 11, 0.05);
  border-radius: var(--km-radius-lg);
  border: 1px solid rgba(245, 158, 11, 0.1);
  color: var(--km-gray-700);
  font-size: 0.9375rem;
  transition: all 0.3s ease;
}

.km-course-features li:hover {
  background: rgba(245, 158, 11, 0.08);
  transform: translateX(2px);
}

.km-course-bridge {
  margin-bottom: var(--km-space-lg);
}

.km-course-transition {
  font-size: 1.0625rem;
  color: var(--km-gray-600);
  font-weight: 500;
  text-align: center;
  line-height: 1.6;
  background: rgba(34, 197, 94, 0.05);
  padding: var(--km-space-md);
  border-radius: var(--km-radius-lg);
  border: 1px solid rgba(34, 197, 94, 0.2);
}

.km-btn-course {
  background: linear-gradient(135deg, var(--km-orange) 0%, #f59e0b 100%);
  box-shadow:
    0 4px 16px rgba(245, 158, 11, 0.3),
    0 8px 24px rgba(11, 37, 69, 0.1);
  position: relative;
  overflow: hidden;
}

.km-btn-course::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.4), transparent);
  animation: course-shine 3s ease-in-out infinite;
}

@keyframes course-shine {
  0%, 100% { left: -100%; }
  50% { left: 100%; }
}

.km-btn-course:hover {
  box-shadow:
    0 6px 20px rgba(245, 158, 11, 0.4),
    0 12px 32px rgba(11, 37, 69, 0.15);
  transform: translateY(-2px);
}

.km-btn-team-link {
  background: var(--km-gradient-orange);
  color: var(--km-white);
  border: 1px solid rgba(245, 158, 11, 0.4);
  box-shadow:
    0 2px 8px rgba(245, 158, 11, 0.3),
    0 8px 24px rgba(11, 37, 69, 0.1);
}

.km-btn-team-link:hover {
  background: linear-gradient(135deg, #f59e0b 0%, #ea580c 100%);
  color: var(--km-white);
  box-shadow:
    0 4px 16px rgba(245, 158, 11, 0.4),
    0 12px 32px rgba(11, 37, 69, 0.15);
}

/* Responsive Design dla nowych sekcji */
@media (max-width: 768px) {
  .km-team-section,
  .km-course-section {
    padding: var(--km-space-2xl) 0;
  }

  .km-team-card,
  .km-course-card--gift {
    padding: var(--km-space-xl);
  }

  .km-team-benefits {
    gap: var(--km-space-md);
  }

  .km-team-benefit {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--km-space-sm);
  }

  .km-team-highlight {
    font-size: 1rem;
  }

  .km-course-features {
    gap: var(--km-space-xs);
  }

  .km-course-features li {
    padding: var(--km-space-sm);
    font-size: 0.875rem;
  }
}

@media (max-width: 640px) {
  .km-team-card,
  .km-course-card--gift {
    padding: var(--km-space-lg);
  }

  .km-team-cta {
    margin-top: var(--km-space-lg);
  }

  .km-course-cta {
    flex-direction: column;
    gap: var(--km-space-sm);
  }

  .km-course-transition {
    font-size: 0.9375rem;
    padding: var(--km-space-sm);
  }
}

/* ========================================
   SEKCJA: PREZENT OD NASZYCH UCZNIÓW
   ======================================== */

.km-students-gift-section {
  background:
    radial-gradient(ellipse 1200px 600px at 50% 0%, rgba(34, 197, 94, 0.04) 0%, transparent 50%),
    radial-gradient(ellipse 800px 400px at 50% 100%, rgba(59, 130, 246, 0.03) 0%, transparent 60%),
    linear-gradient(180deg, #FAFBFC 0%, #FFFFFF 50%, #FEFEFE 100%);
  position: relative;
  padding: calc(var(--km-space-xl) + var(--km-space-lg)) 0;
}

.km-students-gift-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='0.008'/%3E%3C/svg%3E");
  pointer-events: none;
}

.km-students-gift-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--km-space-xl);
  max-width: 1000px;
  margin: 0 auto;
}

.km-students-gift-card {
  background: var(--km-white);
  border: 1px solid var(--km-gray-200);
  border-radius: var(--km-radius-xl);
  padding: var(--km-space-xl);
  box-shadow:
    0 2px 8px rgba(11, 37, 69, 0.06),
    0 16px 32px rgba(11, 37, 69, 0.04);
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, var(--km-white) 0%, #f8fafc 100%);
}

.km-students-gift-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(34, 197, 94, 0.02) 0%, rgba(59, 130, 246, 0.02) 100%);
  opacity: 0;
  transition: opacity 0.4s ease;
}

.km-students-gift-card:hover {
  box-shadow:
    0 4px 16px rgba(11, 37, 69, 0.08),
    0 24px 48px rgba(11, 37, 69, 0.06);
  transform: translateY(-4px);
  border-color: rgba(34, 197, 94, 0.2);
}

.km-students-gift-card:hover::before {
  opacity: 1;
}

.km-gift-content {
  display: grid;
  gap: var(--km-space-lg);
  margin-bottom: var(--km-space-lg);
}

.km-gift-text {
  text-align: center;
}

.km-gift-description {
  font-size: 1.0625rem;
  color: var(--km-gray-700);
  line-height: 1.65;
  max-width: 68ch;
  margin: 0 auto var(--km-space-lg) auto;
  font-weight: 450;
}

.km-gift-benefits {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--km-space-md);
  margin-top: var(--km-space-lg);
  align-items: stretch;
}

.km-gift-benefit {
  display: flex;
  align-items: flex-start;
  gap: var(--km-space-sm);
  padding: var(--km-space-md);
  background: rgba(34, 197, 94, 0.05);
  border-radius: var(--km-radius-lg);
  border: 1px solid rgba(34, 197, 94, 0.1);
  transition: all 0.3s ease;
}

.km-gift-benefit:hover {
  background: rgba(34, 197, 94, 0.08);
  transform: translateX(4px);
  box-shadow: 0 2px 8px rgba(34, 197, 94, 0.15);
}

.km-gift-benefit-icon {
  font-size: 1.75rem;
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
  border-radius: 50%;
  color: white;
  box-shadow: 0 2px 8px rgba(34, 197, 94, 0.3);
}

.km-gift-benefit-text {
  flex: 1;
  padding-top: var(--km-space-xs);
}

/* Gift intro grid with visual */
.km-gift-intro-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: var(--km-space-xl);
  align-items: center;
}

.km-gift-visual { margin: 0; }

.km-gift-image-wrap {
  position: relative;
  width: 100%;
  max-width: 520px;
  margin: 0 auto;
  aspect-ratio: 4 / 3;
  display: grid;
  place-items: center;
}

.km-gift-image-wrap::before {
  content: "";
  position: absolute;
  inset: -8%;
  background: radial-gradient(ellipse at center, rgba(34,197,94,0.10) 0%, rgba(59,130,246,0.06) 40%, transparent 70%);
  filter: blur(36px);
  border-radius: 28px;
  z-index: 0;
}

.km-gift-image {
  position: relative;
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--km-radius-xl);
  border: 1px solid var(--km-gray-200);
  box-shadow:
    0 2px 8px rgba(11, 37, 69, 0.06),
    0 18px 36px rgba(11, 37, 69, 0.08);
}

@media (max-width: 1024px) {
  .km-gift-intro-grid { grid-template-columns: 1fr; gap: var(--km-space-lg); }
  .km-gift-text { text-align: left; }
  .km-gift-description { margin-left: 0; margin-right: 0; }
  .km-gift-image-wrap { max-width: 560px; }
}

@media (max-width: 640px) {
  .km-gift-image-wrap { max-width: 100%; aspect-ratio: auto; }
  .km-gift-image { border-radius: var(--km-radius-lg); }
}

.km-gift-benefit-text strong {
  color: var(--km-navy);
  font-weight: 600;
  display: block;
  margin-bottom: var(--km-space-xs);
}

.km-gift-benefit-text {
  color: var(--km-gray-600);
  font-size: 0.9375rem;
  line-height: 1.5;
  margin: 0;
}

.km-gift-cta {
  text-align: center;
  padding-top: var(--km-space-md);
  border-top: 1px solid var(--km-gray-100);
}

.km-gift-cta--inline {
  padding-top: 0;
  border-top: 0;
  margin-top: var(--km-space-md);
}

.km-btn-gift {
  background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
  box-shadow:
    0 4px 16px rgba(34, 197, 94, 0.3),
    0 8px 24px rgba(11, 37, 69, 0.1);
  position: relative;
  overflow: hidden;
  font-size: 1.125rem;
  padding: 1rem 2.5rem;
}

.km-btn-gift::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.4), transparent);
  animation: gift-shine 3s ease-in-out infinite;
}

@keyframes gift-shine {
  0%, 100% { left: -100%; }
  50% { left: 100%; }
}

.km-btn-gift:hover {
  box-shadow:
    0 6px 20px rgba(34, 197, 94, 0.4),
    0 12px 32px rgba(11, 37, 69, 0.15);
  transform: translateY(-2px);
  background: linear-gradient(135deg, #16a34a 0%, #15803d 100%);
}

.km-gift-note {
  color: var(--km-gray-500);
  font-size: 0.9375rem;
  margin: var(--km-space-sm) 0 0 0;
  font-weight: 500;
  font-style: italic;
}

/* Responsive Design dla sekcji prezentu od uczniów */
@media (max-width: 768px) {
  .km-students-gift-section {
    padding: var(--km-space-2xl) 0;
  }

  .km-students-gift-card {
    padding: var(--km-space-xl);
  }

  .km-gift-benefits {
    grid-template-columns: 1fr;
    gap: var(--km-space-md);
  }

  .km-gift-benefit {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--km-space-sm);
    padding: var(--km-space-md);
  }

  .km-gift-benefit-icon {
    width: 40px;
    height: 40px;
    font-size: 1.5rem;
  }

  .km-gift-description {
    font-size: 1rem;
    max-width: none;
  }

  .km-gift-benefit-text {
    font-size: 0.875rem;
  }
}

@media (max-width: 640px) {
  .km-students-gift-card {
    padding: var(--km-space-lg);
  }

  .km-gift-cta {
    padding-top: var(--km-space-md);
  }

  .km-btn-gift {
    padding: 0.875rem 2rem;
    font-size: 1rem;
  }

  .km-gift-note {
    font-size: 0.875rem;
  }
}

/* Reduced motion preferences */
@media (prefers-reduced-motion: reduce) {
  .km-hero-kitty,
  .km-hero-badge,
  .km-hero-cta .km-btn-primary::after,
  .km-btn-team::after,
  .km-btn-course::after,
  .km-btn-gift::after {
    animation: none;
  }

  .km-highlight::before {
    transition: none;
  }

  [data-reveal] {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .km-team-benefit:hover,
  .km-course-features li:hover,
  .km-gift-benefit:hover {
    transform: none;
  }
}

/* ======================================================================
   /dolacz Page - New Sections Styles
   ====================================================================== */

/* Skills Section */
.km-skills-section {
  background: linear-gradient(180deg, #FFFFFF 0%, #F8FAFC 100%);
  padding: var(--km-space-3xl) 0;
}

.km-skills-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--km-space-xl);
  margin-top: var(--km-space-2xl);
}

.km-skill-item {
  background: var(--km-white);
  padding: var(--km-space-xl);
  border-radius: var(--km-radius-xl);
  border: 1px solid rgba(11, 37, 69, 0.08);
  box-shadow: var(--km-shadow-sm);
  transition: all var(--km-transition);
  text-align: center;
}

.km-skill-item:hover {
  transform: translateY(-4px);
  box-shadow: var(--km-shadow-lg);
  border-color: rgba(11, 37, 69, 0.12);
}

.km-skill-icon {
  font-size: 2.5rem;
  margin-bottom: var(--km-space-md);
  display: block;
}

.km-skill-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--km-navy);
  margin-bottom: var(--km-space-sm);
}

.km-skill-description {
  color: var(--km-gray-600);
  font-size: 1rem;
  line-height: 1.6;
}

/* Target Section */
.km-target-section {
  background: var(--km-white);
  padding: var(--km-space-3xl) 0;
}

.km-target-content {
  max-width: 800px;
  margin: 0 auto;
  text-align: center;
}

.km-target-text {
  font-size: 1.125rem;
  color: var(--km-gray-700);
  margin-bottom: var(--km-space-lg);
  line-height: 1.7;
}

.km-target-highlight {
  background: linear-gradient(135deg, rgba(245, 158, 11, 0.08) 0%, rgba(59, 130, 246, 0.06) 100%);
  border: 1px solid rgba(245, 158, 11, 0.2);
  border-radius: var(--km-radius-lg);
  padding: var(--km-space-xl);
  margin-top: var(--km-space-xl);
}

.km-target-highlight p {
  color: var(--km-gray-700);
  font-size: 1rem;
  margin: 0;
  font-style: italic;
}

/* Rewards Section */
.km-rewards-section {
  background: linear-gradient(180deg, #F8FAFC 0%, #FFFFFF 100%);
  padding: var(--km-space-3xl) 0;
}

.km-rewards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: var(--km-space-xl);
  margin-top: var(--km-space-2xl);
}

.km-reward-item {
  background: var(--km-white);
  padding: var(--km-space-xl);
  border-radius: var(--km-radius-lg);
  border: 1px solid rgba(11, 37, 69, 0.08);
  box-shadow: var(--km-shadow-sm);
  transition: all var(--km-transition);
  text-align: center;
}

.km-reward-item:hover {
  transform: translateY(-2px);
  box-shadow: var(--km-shadow-md);
  border-color: rgba(11, 37, 69, 0.12);
}

.km-reward-icon {
  font-size: 2rem;
  margin-bottom: var(--km-space-md);
  display: block;
}

.km-reward-title {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--km-navy);
  margin-bottom: var(--km-space-sm);
}

.km-reward-description {
  color: var(--km-gray-600);
  font-size: 0.9375rem;
  line-height: 1.6;
}

/* Social Proof Section */
.km-social-proof-section {
  background: var(--km-navy);
  padding: var(--km-space-xl) 0;
}

.km-social-proof {
  text-align: center;
}

.km-social-proof-text {
  color: var(--km-white);
  font-size: 1.125rem;
  font-weight: 500;
  margin: 0;
}

.km-social-proof-text strong {
  color: var(--km-orange);
  font-weight: 700;
}

/* FAQ Section */
.km-faq-section {
  background: var(--km-white);
  padding: var(--km-space-3xl) 0;
}

.km-faq-list {
  max-width: 800px;
  margin: 0 auto;
  margin-top: var(--km-space-2xl);
}

.km-faq-item {
  border-bottom: 1px solid rgba(11, 37, 69, 0.1);
  padding: var(--km-space-xl) 0;
}

.km-faq-item:last-child {
  border-bottom: none;
}

.km-faq-question {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--km-navy);
  margin-bottom: var(--km-space-sm);
}

.km-faq-answer {
  color: var(--km-gray-600);
  font-size: 1rem;
  line-height: 1.6;
  margin: 0;
}

/* Application Form Section */
.km-application-section {
  background: linear-gradient(180deg, #F8FAFC 0%, #FFFFFF 100%);
  padding: var(--km-space-3xl) 0;
}

.km-application-card {
  max-width: 600px;
  margin: 0 auto;
  background: var(--km-white);
  border-radius: var(--km-radius-2xl);
  border: 1px solid rgba(11, 37, 69, 0.08);
  box-shadow: var(--km-shadow-lg);
  overflow: hidden;
}

.km-application-header {
  text-align: center;
  padding: var(--km-space-2xl) var(--km-space-xl) var(--km-space-xl);
  background: linear-gradient(135deg, rgba(11, 37, 69, 0.02) 0%, rgba(59, 130, 246, 0.01) 100%);
}

.km-application-title {
  font-size: 1.875rem;
  font-weight: 800;
  color: var(--km-navy);
  margin-bottom: var(--km-space-sm);
}

.km-application-subtitle {
  color: var(--km-gray-600);
  font-size: 1.125rem;
  line-height: 1.6;
  margin: 0;
}

.km-application-form {
  padding: 0 var(--km-space-xl) var(--km-space-2xl);
}

.km-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--km-space-lg);
  margin-bottom: var(--km-space-lg);
}

.km-form-input,
.km-form-textarea {
  width: 100%;
  padding: 1rem 1.25rem;
  border: 2px solid rgba(11, 37, 69, 0.12);
  border-radius: var(--km-radius-lg);
  font-size: 1rem;
  font-family: var(--km-font-primary);
  background: var(--km-white);
  transition: all var(--km-transition);
}

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

.km-form-textarea {
  resize: vertical;
  min-height: 100px;
}

.km-form-consent {
  margin: var(--km-space-lg) 0;
}

.km-checkbox {
  display: flex;
  align-items: center;
  gap: var(--km-space-sm);
  cursor: pointer;
  font-size: 0.9375rem;
  color: var(--km-gray-700);
}

.km-checkbox input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  margin: 0;
  appearance: none;
  -webkit-appearance: none;
}

.km-checkbox-mark {
  display: inline-block;
  width: 1.25rem;
  height: 1.25rem;
  border: 2px solid rgba(11, 37, 69, 0.2);
  border-radius: var(--km-radius-sm);
  position: relative;
  transition: all var(--km-transition);
}

.km-checkbox input[type="checkbox"]:checked + .km-checkbox-mark {
  background: var(--km-blue);
  border-color: var(--km-blue);
}

.km-checkbox input[type="checkbox"]:checked + .km-checkbox-mark::after {
  content: "✓";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: var(--km-white);
  font-size: 0.875rem;
  font-weight: bold;
}

/* Focus ring for keyboard users when checkbox has focus */
.km-checkbox input[type="checkbox"]:focus-visible + .km-checkbox-mark {
  box-shadow: 0 0 0 3px rgba(59,130,246,0.35);
}

.km-form-status {
  min-height: 1.5rem;
  margin: var(--km-space-sm) 0;
  font-size: 0.875rem;
  text-align: center;
}

.km-form-success {
  display: none;
  text-align: center;
  padding: var(--km-space-2xl) var(--km-space-xl);
  background: linear-gradient(135deg, rgba(34, 197, 94, 0.08) 0%, rgba(59, 130, 246, 0.04) 100%);
}

.km-form-success.show {
  display: block;
}

.km-form-success-icon {
  font-size: 3rem;
  margin-bottom: var(--km-space-lg);
}

.km-form-success h4 {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--km-navy);
  margin-bottom: var(--km-space-sm);
}

.km-form-success p {
  color: var(--km-gray-600);
  font-size: 1rem;
  margin: 0;
}

.km-btn-full {
  width: 100%;
  justify-content: center;
}

/* Final CTA Section */
.km-final-cta-section {
  background: var(--km-navy);
  padding: var(--km-space-3xl) 0;
}

.km-final-cta-card {
  max-width: 600px;
  margin: 0 auto;
  text-align: center;
  background: rgba(255, 255, 255, 0.05);
  border-radius: var(--km-radius-2xl);
  padding: var(--km-space-2xl);
  border: 1px solid rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
}

.km-final-cta-title {
  font-size: 2rem;
  font-weight: 800;
  color: var(--km-white);
  margin-bottom: var(--km-space-sm);
}

.km-final-cta-subtitle {
  color: rgba(255, 255, 255, 0.8);
  font-size: 1.125rem;
  margin-bottom: var(--km-space-xl);
}

.km-final-cta-card .km-btn-primary {
  background: var(--km-orange);
  border-color: var(--km-orange);
  color: var(--km-white);
  font-weight: 700;
  padding: 1rem 2.5rem;
  font-size: 1.125rem;
}

.km-final-cta-card .km-btn-primary:hover {
  background: #ea580c;
  border-color: #ea580c;
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(245, 158, 11, 0.4);
}

/* Hero secondary button */
.km-btn-hero-secondary {
  background: transparent;
  border: 2px solid var(--km-blue);
  color: var(--km-blue);
  font-weight: 600;
}

.km-btn-hero-secondary:hover {
  background: var(--km-blue);
  color: var(--km-white);
  transform: translateY(-2px);
}

/* Responsive Design for /dolacz page */
@media (max-width: 768px) {
  .km-skills-grid {
    grid-template-columns: 1fr;
    gap: var(--km-space-lg);
  }

  .km-rewards-grid {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--km-space-lg);
  }

  .km-form-row {
    grid-template-columns: 1fr;
    gap: var(--km-space-md);
  }

  .km-application-card {
    margin: 0 var(--km-space-md);
  }

  .km-application-header,
  .km-application-form {
    padding-left: var(--km-space-lg);
    padding-right: var(--km-space-lg);
  }

  .km-final-cta-card {
    margin: 0 var(--km-space-md);
    padding: var(--km-space-xl);
  }

  .km-final-cta-title {
    font-size: 1.75rem;
  }
}

@media (max-width: 640px) {
  .km-skill-item,
  .km-reward-item {
    padding: var(--km-space-lg);
  }

  .km-application-title {
    font-size: 1.5rem;
  }

  .km-application-subtitle {
    font-size: 1rem;
  }

  .km-final-cta-title {
    font-size: 1.5rem;
  }

  .km-final-cta-subtitle {
    font-size: 1rem;
  }
}

/* Reduced motion preferences for new sections */
@media (prefers-reduced-motion: reduce) {
  .km-skill-item:hover,
  .km-reward-item:hover,
  .km-final-cta-card .km-btn-primary:hover {
    transform: none;
  }
}
