



h1 {
  line-height: 1.2;
  margin: 0 0 16px;
  font-size: clamp(40px, 5vw, 70px);
  font-weight: 900;
}

h2 {
  line-height: 1.2;
  margin: 0 0 16px;
  font-size: clamp(20px, 4vw, 40px);
  font-weight: 600;
  text-align: center;
}

h3 {
  line-height: 1.2;
  margin: 0 0 16px;
}

h4 {
  line-height: 1.2;
  margin: 0 0 10px;
  font-size: clamp(16px, 2.5vw, 30px);
  font-weight: 400;
}

.ticker.full-bleed {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  border-left: 0;
  border-right: 0;
  border-radius: 0;
}

.profile-text h1 {
  margin: 0;
  line-height: 1.1;
  word-break: break-word;
  overflow-wrap: anywhere;
}

#education h2 {
  text-wrap: balance;
  letter-spacing: -0.01em;
  margin-bottom: 0.8em;
}

@media (prefers-reduced-motion: reduce) {
  #fx {
    transform: none !important;
  }

  [data-parallax] {
    transform: none !important;
  }

  .blob {
    opacity: .2;
  }

}

/* Section paddings управляются через .section в variables.css */

.hero-section .ticker.full-bleed{
  width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  border-left: 0 !important;
  border-right: 0 !important;
  border-radius: 0 !important;
}

h2.title-with-icon{
  display: flex !important;          
  justify-content: center;           
  align-items: center;               
  text-align: center;                
  gap: 0.2em;                        
  margin-bottom: var(--gap-stack);
}

@media (prefers-reduced-motion: reduce){
  *{ animation: none !important; transition: none !important; }
}


/* Keep ticker moving even when user prefers-reduced-motion, as requested */
@media (prefers-reduced-motion: reduce){
  .ticker--js .ticker-track{ animation: none !important; } /* already JS-driven */
}
