/* ==========================================
   891 ДОБРОЕ СЕРДЦЕ — Тверской хоспис «Анастасия»
   Design System & Full Styles
   Semantic HTML5 + CSS3 (Modern features)
   ========================================== */

/* ---------- Google Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=Caveat:wght@400;700&family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600&family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400&family=Bad+Script&family=Montserrat:wght@400;500;600;700;800;900&family=PT+Serif:ital,wght@0,400;0,700;1,400&display=swap');

/* ---------- CSS Custom Properties (Design Tokens) ---------- */
:root {
  /* Palette */
  --color-bg: #FFFFFF;
  --color-bg-alt: #F4F5F0;
  --color-bg-card: #FFFFFF;
  --color-green: #58724D;
  --color-green-dark: #3F5F3B;
  --color-green-deep: #5A744F;
  --color-green-pale: #B3CBB0;
  --color-green-mist: #D5E4D2;
  --color-green-wash: #EBF1EA;
  --color-green-soft: #7A9E75;
  --color-green-light: #F4F7F3;
  --color-stone-50: #FAFAF9;
  --color-stone-100: #F5F5F4;
  --color-stone-200: #E7E5E4;
  --color-stone-300: #D6D3D1;
  --color-stone-400: #A8A29E;
  --color-stone-500: #78716C;
  --color-stone-600: #57534E;
  --color-stone-700: #44403C;
  --color-stone-800: #1E291B;

  /* Typography */
  --font-sans: 'Inter', ui-sans-serif, system-ui, sans-serif;
  --font-serif: 'Playfair Display', Georgia, serif;
  --font-script: 'Caveat', 'Bad Script', cursive;
  --font-mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, monospace;

  /* Spacing scale */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;

  /* Border radius */
  --radius-sm: 0.375rem;
  --radius-md: 0.75rem;
  --radius-lg: 1rem;
  --radius-xl: 1.25rem;
  --radius-2xl: 1.5rem;
  --radius-3xl: 1.875rem;
  --radius-full: 9999px;

  /* Shadows */
  --shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -2px rgba(0, 0, 0, .05);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -4px rgba(0, 0, 0, .05);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .08), 0 8px 10px -6px rgba(0, 0, 0, .04);

  /* Transitions */
  --ease-out: cubic-bezier(.25, .46, .45, .94);
  --transition-base: 0.3s var(--ease-out);
}

/* ---------- Reset & Base ---------- */
*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-sans);
  background: var(--color-bg);
  color: var(--color-stone-800);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: 1.6;
  overflow-x: hidden;
  min-height: 100vh;
}

::selection {
  background: rgba(94, 121, 84, 0.2);
  color: var(--color-green-deep);
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
}

button {
  cursor: pointer;
  border: none;
  background: none;
  font: inherit;
}

ul,
ol {
  list-style: none;
}

/* ---------- Scrollbar ---------- */
::-webkit-scrollbar {
  width: 8px;
}

::-webkit-scrollbar-track {
  background: var(--color-bg);
}

::-webkit-scrollbar-thumb {
  background: var(--color-green-pale);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--color-green-soft);
}

/* ---------- Utility Classes ---------- */
.container {
  width: 100%;
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 var(--space-4);
}

@media (min-width: 640px) {
  .container {
    padding: 0 var(--space-6);
  }
}

@media (min-width: 1024px) {
  .container {
    padding: 0 var(--space-8);
  }
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ---------- Animations (keyframes) ---------- */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(24px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@keyframes scaleIn {
  from {
    opacity: 0;
    transform: scale(0.95);
  }

  to {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-20px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes slideInRight {
  from {
    transform: translateX(100%);
  }

  to {
    transform: translateX(0);
  }
}

@keyframes slideOutRight {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(100%);
  }
}

@keyframes pulse {

  0%,
  100% {
    opacity: 1;
  }

  50% {
    opacity: .7;
  }
}

@keyframes bounce {

  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-6px);
  }
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

@keyframes progressFill {
  from {
    width: 0;
  }
}

@keyframes heartPulse {

  0%,
  100% {
    transform: scale(1);
  }

  50% {
    transform: scale(1.15);
  }
}

.animate-fade-in-up {
  animation: fadeInUp 0.6s var(--ease-out) both;
}

.animate-fade-in {
  animation: fadeIn 0.5s var(--ease-out) both;
}

.animate-scale-in {
  animation: scaleIn 0.5s var(--ease-out) both;
}

.animate-bounce {
  animation: bounce 1.5s infinite;
}

.animate-pulse {
  animation: pulse 3s infinite;
}

.animate-spin {
  animation: spin 0.8s linear infinite;
}

/* Stagger delays via JS data-delay attribute */
[data-delay="1"] {
  animation-delay: 0.1s;
}

[data-delay="2"] {
  animation-delay: 0.2s;
}

[data-delay="3"] {
  animation-delay: 0.3s;
}

[data-delay="4"] {
  animation-delay: 0.4s;
}

[data-delay="5"] {
  animation-delay: 0.5s;
}

/* IntersectionObserver reveal targets */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s var(--ease-out), transform 0.6s var(--ease-out);
}

.reveal.revealed {
  opacity: 1;
  transform: translateY(0);
}

/* ======================================
   HEADER
   ====================================== */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 40;
  transition: background var(--transition-base), box-shadow var(--transition-base), padding var(--transition-base);
  padding: var(--space-5) 0;
}

.site-header.scrolled {
  background: rgba(250, 249, 245, 0.75);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: var(--shadow-sm);
  padding: var(--space-3) 0;
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* Logo */
/* Logo header (Separate absolute element) */
.site-header .container {
  position: relative;
}

.logo-header {
  position: absolute;
  left: var(--space-4);
  top: 50%;
  transform: translateY(-55%);
  /* Slightly raised above the centerline */
  z-index: 50;
  display: flex;
  align-items: center;
  transition: all var(--transition-base);
}

.logo-header:hover {
  transform: translateY(-55%) scale(1.02);
}

.logo-header__img {
  height: 70px;
  width: auto;
  display: block;
  transition: height var(--transition-base);
}

.site-header.scrolled .logo-header__img {
  height: 55px;
}

/* Logo placeholder inside header-inner to reserve space */
.logo-placeholder {
  width: 240px;
  height: 1px;
  flex-shrink: 0;
  display: none;
  transition: width var(--transition-base);
}

@media (min-width: 768px) {
  .logo-placeholder {
    display: block;
  }
}

/* Desktop Nav */
.nav-desktop {
  display: none;
  align-items: center;
  gap: var(--space-8);
}

@media (min-width: 768px) {
  .nav-desktop {
    display: flex;
  }
}

.nav-desktop__link {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-stone-600);
  position: relative;
  padding: var(--space-1) 0;
  transition: color var(--transition-base);
  text-decoration: none !important;
}

.nav-desktop__link::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--color-green);
  transition: width var(--transition-base);
}

.nav-desktop__link:hover {
  color: var(--color-green);
  text-decoration: none !important;
}

.nav-desktop__link:hover::after {
  width: 100%;
}

/* Header CTA */
.header-cta {
  display: none;
  align-items: center;
}

@media (min-width: 768px) {
  .header-cta {
    display: flex;
  }
}

/* Shared button styles */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-weight: 600;
  border-radius: var(--radius-full);
  transition: all var(--transition-base);
  white-space: nowrap;
}

.btn:hover {
  text-decoration: none !important;
  transform: translateY(-2px);
}

.btn:active {
  transform: translateY(0) scale(0.98);
}

.btn--primary {
  background: var(--color-green);
  color: var(--color-bg);
  padding: 0.625rem 1.25rem;
  font-size: 0.875rem;
  box-shadow: var(--shadow-sm);
}

.btn--primary:hover {
  background: var(--color-green-dark);
  color: var(--color-bg) !important;
  box-shadow: var(--shadow-md);
}

.btn--primary-lg {
  background: var(--color-green);
  color: var(--color-bg);
  padding: 1rem 2rem;
  font-size: 1rem;
  font-weight: 700;
  box-shadow: var(--shadow-md);
}

.btn--primary-lg:hover {
  background: var(--color-green-dark);
  color: var(--color-bg) !important;
  box-shadow: var(--shadow-lg);
}

.btn--outline {
  border: 2px solid var(--color-green);
  color: var(--color-green);
  padding: 1rem 2rem;
  font-size: 1rem;
  font-weight: 700;
  background: transparent;
}

.btn--outline:hover {
  border-color: var(--color-green-dark);
  color: var(--color-green-dark);
  background: var(--color-green-wash);
}

.btn--header-pill {
  border: 2px solid var(--color-green);
  color: var(--color-green);
  padding: 0.5rem 1.25rem;
  font-size: 0.875rem;
  font-weight: 600;
  background: transparent;
  border-radius: var(--radius-full);
}

.btn--header-pill:hover {
  background: var(--color-green);
  color: var(--color-bg) !important;
}

.btn__icon {
  width: 1.125rem;
  height: 1.125rem;
}

.btn__icon--sm {
  width: 1rem;
  height: 1rem;
}

/* Mobile menu toggle */
.mobile-toggle {
  display: flex;
  padding: var(--space-2);
  color: var(--color-stone-700);
  transition: color var(--transition-base);
  margin-left: auto;
}

.mobile-toggle:hover {
  color: var(--color-green);
}

@media (min-width: 768px) {
  .mobile-toggle {
    display: none;
  }
}

.mobile-toggle svg {
  width: 1.5rem;
  height: 1.5rem;
}

/* Mobile Drawer */
.mobile-menu {
  position: fixed;
  inset: 0;
  top: 70px;
  z-index: 30;
  display: none;
  flex-direction: column;
  gap: var(--space-6);
  padding: var(--space-6);
  background: rgba(244, 247, 243, 0.8);
  /* 80% opacity soft brand green */
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: var(--shadow-lg);
  border-bottom: 1px solid var(--color-stone-100);
  animation: slideDown 0.3s var(--ease-out);
}

.mobile-menu.open {
  display: flex;
}

@media (min-width: 768px) {
  .mobile-menu {
    display: none !important;
  }
}

.mobile-menu__links {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.mobile-menu__link {
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-stone-700);
  padding: var(--space-2) 0;
  border-bottom: 1px solid var(--color-stone-100);
  text-align: left;
  transition: color var(--transition-base);
}

.mobile-menu__link:last-child {
  border-bottom: none;
}

.mobile-menu__link:hover {
  color: var(--color-green);
}

.mobile-menu .btn--primary {
  width: 100%;
  justify-content: center;
  padding: var(--space-3) 0;
  border-radius: var(--radius-xl);
}

/* ======================================
   HERO SECTION
   ====================================== */
.hero {
  position: relative;
  padding: 6rem 0 7rem;
  overflow: hidden;
  background: var(--color-bg-card);
}

/* Animated Blur Blobs along the left edge only */
.hero__blur-blobs {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  pointer-events: none;
  z-index: 1;
}

.hero__blob {
  position: absolute;
  pointer-events: none;
  filter: blur(100px);
  opacity: 0.8;
  mix-blend-mode: multiply;
  will-change: transform, border-radius;
}

.hero__blob--1 {
  top: 10%;
  left: -200px;
  width: 480px;
  height: 580px;
  background: radial-gradient(circle, rgba(88, 114, 77, 0.2) 0%, rgba(138, 168, 133, 0.08) 55%, rgba(255, 255, 255, 0) 75%);
  animation: morphBlob1 24s infinite alternate ease-in-out;
}

.hero__blob--2 {
  top: 35%;
  left: -180px;
  width: 400px;
  height: 500px;
  background: radial-gradient(circle, rgba(179, 203, 176, 0.22) 0%, rgba(213, 228, 210, 0.08) 55%, rgba(255, 255, 255, 0) 75%);
  animation: morphBlob2 18s infinite alternate ease-in-out;
}

@keyframes morphBlob1 {
  0% {
    transform: translate(0, 0) scale(1) rotate(0deg);
    border-radius: 42% 58% 70% 30% / 45% 45% 55% 55%;
  }

  33% {
    transform: translate(30px, 50px) scale(1.08) rotate(60deg);
    border-radius: 70% 30% 52% 48% / 60% 40% 60% 40%;
  }

  66% {
    transform: translate(-15px, 80px) scale(0.92) rotate(120deg);
    border-radius: 48% 52% 30% 70% / 40% 60% 40% 60%;
  }

  100% {
    transform: translate(5px, -15px) scale(1.04) rotate(180deg);
    border-radius: 58% 42% 65% 35% / 50% 50% 50% 50%;
  }
}

@keyframes morphBlob2 {
  0% {
    transform: translate(0, 0) scale(1) rotate(0deg);
    border-radius: 50% 50% 30% 70% / 50% 60% 40% 50%;
  }

  50% {
    transform: translate(40px, -30px) scale(0.88) rotate(-90deg);
    border-radius: 30% 70% 60% 40% / 60% 30% 70% 40%;
  }

  100% {
    transform: translate(-5px, 60px) scale(1.06) rotate(90deg);
    border-radius: 60% 40% 40% 60% / 40% 60% 50% 40%;
  }
}

.hero__canvas {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 21;
  opacity: 0;
  transition: opacity 1s var(--ease-out);
}

.hero__canvas.active {
  opacity: 0.85;
}

@media (min-width: 1024px) {
  .hero {
    padding: 5rem 0px 9rem;
  }
}

.hero__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
  align-items: center;
}

@media (min-width: 1024px) {
  .hero__grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-8);
  }
}

/* Hero content */
.hero__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  position: relative;
  z-index: 20;
}

@media (min-width: 640px) {
  .hero__content {
    gap: var(--space-8);
  }
}

.hero__tag {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  color: var(--color-green-deep);
  font-size: 1.2rem;
  font-weight: 400;
  letter-spacing: 0.03em;
}

.hero__tag svg {
  width: 1rem;
  height: 1rem;
  color: var(--color-green);
}

.hero__logo-wrap {
  position: relative;
  padding: var(--space-2) 0;
  max-width: 520px;
  margin-left: -20px;
}

@media (max-width: 1440px) {
  .hero__logo-wrap {
    max-width: 380px;
  }
}

@media (max-width: 1200px) {
  .hero__logo-wrap {
    max-width: 320px;
  }
}

.hero__logo-wrap svg {
  width: 100%;
  height: auto;
  color: #0d6b36;
}

.hero__city {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.hero__city-name {
  font-size: 0.875rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-stone-500);
}

.hero__city-heart {
  font-size: 1rem;
  color: var(--color-green);
}

.hero__city-slogan {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--color-green-deep);
}

.hero__desc {
  font-size: 1rem;
  color: var(--color-stone-600);
  max-width: 30rem;
  line-height: 1.7;
  margin-top: 2px;
  margin: 0 0 2px 0;
}

@media (min-width: 640px) {
  .hero__desc {
    font-size: 1.125rem;
  }
}

.hero__buttons {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  padding-top: var(--space-2);
}

@media (min-width: 640px) {
  .hero__buttons {
    flex-direction: row;
    align-items: center;
  }
}

/* Hero image section */
.hero__visual {
  display: flex;
  justify-content: center;
  position: relative;
  padding: 0 var(--space-6);
}

.hero__image-frame {
  position: relative;
  width: 100%;
  max-width: 38rem;
  aspect-ratio: 1376 / 768;
  border-radius: 2rem;
  overflow: hidden;
  box-shadow: var(--shadow-xl);
  border: 4px solid white;
  background: var(--color-stone-100);
}

.hero__slideshow {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
}

/* Dots Navigation for Slideshow */
.hero__slideshow-dots {
  position: absolute;
  bottom: var(--space-5);
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
  display: flex;
  gap: var(--space-2);
}

.hero__slideshow-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.4);
  border: 1px solid rgba(0, 0, 0, 0.15);
  cursor: pointer;
  padding: 0;
  transition: all var(--transition-base);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.hero__slideshow-dot:hover {
  background: rgba(255, 255, 255, 0.7);
  transform: scale(1.15);
}

.hero__slideshow-dot.active {
  background: #FFFFFF;
  width: 24px;
  /* Premium Pill Shape */
  border-radius: 5px;
  box-shadow: var(--shadow-sm);
}

.hero__image-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: opacity 1.5s ease-in-out;
}

.hero__image-fg {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 70%;
  height: 80%;
  object-fit: contain;
  object-position: bottom center;
  z-index: 4;
  pointer-events: none;
}

.hero__image-overlay {
  position: absolute;
  inset: -2px;
  background:
    linear-gradient(to right, #ffffff 0%, rgba(255, 255, 255, 0.95) 5%, rgba(255, 255, 255, 0) 25%),
    linear-gradient(to bottom, #ffffff 0%, rgba(255, 255, 255, 0.95) 3%, rgba(255, 255, 255, 0) 15%),
    linear-gradient(to top, #ffffff 0%, rgba(255, 255, 255, 0.95) 3%, rgba(255, 255, 255, 0) 15%);
  pointer-events: none;
  z-index: 2;
}

.hero__image-label {
  position: absolute;
  bottom: 1rem;
  right: 1rem;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(4px);
  color: white;
  font-size: 0.625rem;
  padding: 0.25rem 0.75rem;
  border-radius: 2px;
  font-weight: 300;
  letter-spacing: 0.03em;
  z-index: 5;
}

.hero__heart-most {
  display: none;
}

@media (min-width: 1024px) {
  .hero__visual {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 55%;
    height: 100%;
    padding: 0;
    z-index: 15;
  }

  .hero__image-frame {
    width: 100%;
    height: 100%;
    max-width: none;
    aspect-ratio: auto;
    border-radius: 0;
    border: none;
    box-shadow: none;
  }

  .hero__heart-most {
    display: block;
    position: absolute;
    left: 0%;
    top: 36.5%;
    width: 136px;
    height: 151px;
    z-index: 3;
    pointer-events: none;
    animation: floatHeart 4s ease-in-out infinite;
  }
}

@keyframes floatHeart {

  0%,
  100% {
    transform: translateY(-50%) translateY(0);
  }

  50% {
    transform: translateY(-50%) translateY(-8px);
  }
}

/* Wave separator */
.hero__wave {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  overflow: hidden;
  line-height: 0;
  z-index: 21;
  pointer-events: none;
}

.hero__wave svg {
  position: relative;
  display: block;
  width: 100%;
  height: 50px;
}

@media (min-width: 640px) {
  .hero__wave svg {
    height: 80px;
  }
}

@media (min-width: 1024px) {
  .hero__wave svg {
    height: 140px;
  }
}

/* ======================================
   VALUES SECTION
   ====================================== */
.values {
  padding: var(--space-1) 0;
  background: var(--color-bg-alt);
  border-bottom: 1px solid var(--color-green-mist);
}

@media (min-width: 640px) {
  .values {
    padding: var(--space-2) 0;
  }
}

.section-heading {
  text-align: center;
  margin-bottom: var(--space-16);
}

.section-heading__title {
  font-family: var(--font-serif);
  font-size: 1.875rem;
  font-weight: 400;
  color: var(--color-green-deep);
  letter-spacing: -0.02em;
}

@media (min-width: 640px) {
  .section-heading__title {
    font-size: 2.25rem;
  }
}

@media (min-width: 1024px) {
  .section-heading__title {
    font-size: 3rem;
  }
}

.section-heading__line {
  width: 4rem;
  height: 4px;
  background: var(--color-green-pale);
  margin: var(--space-4) auto 0;
  border-radius: var(--radius-full);
}

/* Section Heading with Backdrop */
.section-heading--backdrop {
  position: relative;
  text-align: center;
  margin-bottom: var(--space-12);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.section-heading--backdrop .section-heading__backdrop {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -55%);
  font-family: 'Montserrat', sans-serif;
  font-size: 7.5rem;
  font-weight: 800;
  color: transparent;
  -webkit-text-stroke: 1.5px rgba(90, 116, 79, 0.07);
  pointer-events: none;
  z-index: 1;
  user-select: none;
  letter-spacing: 0.05em;
  line-height: 1;
}

@media (min-width: 768px) {
  .section-heading--backdrop .section-heading__backdrop {
    font-size: 11.5rem;
    -webkit-text-stroke: 2px rgba(90, 116, 79, 0.05);
  }
}

.section-heading--backdrop .section-heading__title {
  position: relative;
  z-index: 2;
  font-family: var(--font-serif);
  font-weight: 700;
  color: var(--color-green-deep);
  display: inline-block;
  background: var(--color-bg);
  /* Mask the line behind */
  padding: 0 var(--space-6);
  margin: 0;
  font-size: 1.625rem;
  letter-spacing: 0.15em;
}

@media (min-width: 768px) {
  .section-heading--backdrop .section-heading__title {
    font-size: 2.25rem;
  }
}

.section-heading--backdrop .section-heading__line {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  width: 100%;
  height: 1px;
  background: rgba(90, 116, 79, 0.12);
  z-index: 1;
  margin: 0;
  transform: translateY(-50%);
  border-radius: 0;
}

.values__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}

@media (min-width: 768px) {
  .values__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
  }
}

@media (min-width: 1024px) {
  .values__grid {
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-5);
  }
}

.value-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--space-4) var(--space-2);
  background: transparent;
  border-radius: 0;
  border: none;
  box-shadow: none;
  transition: transform var(--transition-base);
  cursor: pointer;
}

.value-card:hover {
  transform: translateY(-4px);
}

.value-card.active {
  transform: translateY(-2px);
}

.value-card__icon {
  font-size: 3rem;
  color: var(--color-green);
  margin-bottom: var(--space-4);
  transition: transform var(--transition-base), color var(--transition-base);
  display: flex;
  align-items: center;
  justify-content: center;
}

@media (min-width: 640px) {
  .value-card__icon {
    font-size: 3.5rem;
  }
}

.value-card:hover .value-card__icon {
  transform: scale(1.06);
  color: var(--color-green-dark);
}

.value-card.active .value-card__icon {
  transform: scale(1.06);
  color: var(--color-green-dark);
}

.value-card__icon iconify-icon {
  display: block;
}

.value-card__title {
  font-family: var(--font-serif);
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-stone-700);
  line-height: 1.4;
  max-width: 18rem;
  margin: 0 auto;
  position: relative;
  padding-bottom: 6px;
  display: inline-block;
  transition: color var(--transition-base);
}

@media (min-width: 640px) {
  .value-card__title {
    font-size: 1rem;
  }
}

.value-card__title::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--color-green);
  transition: width var(--transition-base);
}

.value-card:hover .value-card__title {
  color: var(--color-green-dark);
}

.value-card:hover .value-card__title::after {
  width: 100%;
}

.value-card.active .value-card__title {
  color: var(--color-green-dark);
}

.value-card.active .value-card__title::after {
  width: 100%;
}

/* Two carets double chevron indicator */
.value-card__indicator {
  opacity: 0;
  transform: translateY(-8px);
  color: var(--color-green);
  width: 24px;
  height: 24px;
  margin-top: var(--space-3);
  transition: opacity 0.3s ease, transform 0.4s var(--ease-out), color 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

.value-card__indicator svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  stroke-width: 2.5;
  transition: transform 0.4s ease;
}

.value-card:hover .value-card__indicator {
  opacity: 1;
  transform: translateY(0);
  animation: chevronFloat 1.4s infinite ease-in-out;
}

.value-card.active .value-card__indicator {
  opacity: 1;
  transform: translateY(0);
  color: var(--color-green-dark);
}

.value-card.active .value-card__indicator svg {
  transform: rotate(180deg);
}

@keyframes chevronFloat {

  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(4px);
  }
}

/* Values Panels Layout */
.values__details {
  margin-top: 0;
  position: relative;
  width: 100%;
}

.values__panel {
  display: none;
  opacity: 0;
}

.values__panel.active {
  display: block;
  animation: panelSlideInUp 0.45s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes panelSlideInUp {
  0% {
    opacity: 0;
    transform: translateY(20px);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Expanded content panel card */
.tab-panel-card {
  background: white;
  border-radius: var(--radius-3xl);
  padding: var(--space-6) var(--space-4);
  border: 1px solid var(--color-stone-100);
  box-shadow: var(--shadow-md);
  text-align: left;
  margin: 16px 4px 20px 4px;
  /* Exactly 16px below the buttons, 20px above the next section */
}

@media (min-width: 768px) {
  .tab-panel-card {
    padding: var(--space-10) var(--space-12);
  }
}

.tab-panel-card__title {
  font-family: var(--font-serif);
  font-size: 1.375rem;
  font-weight: 700;
  color: var(--color-stone-800);
  margin-bottom: var(--space-6);
  line-height: 1.3;
}

@media (min-width: 768px) {
  .tab-panel-card__title {
    font-size: 1.875rem;
  }
}

.tab-text-lead {
  font-size: 0.9375rem;
  color: var(--color-stone-700);
  line-height: 1.7;
  font-weight: 400;
}

@media (min-width: 768px) {
  .tab-text-lead {
    font-size: 1.0625rem;
  }
}

.accent-box {
  background: var(--color-green-wash);
  border-left: 4px solid var(--color-green);
  border-radius: var(--radius-md);
  padding: var(--space-5) var(--space-6);
  margin-top: var(--space-6);
}

.tab-text-highlight {
  font-size: 0.9375rem;
  color: var(--color-stone-700);
  line-height: 1.6;
  margin: 0;
}

@media (min-width: 768px) {
  .tab-text-highlight {
    font-size: 1rem;
  }
}

/* 2-Column layout inside Tab 1 */
.tab-panel-card__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  align-items: start;
}

@media (min-width: 992px) {
  .tab-panel-card__grid {
    grid-template-columns: 1.4fr 1fr;
    gap: var(--space-8);
  }
}

.tab-panel-card__main {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

/* Photos under main text */
.tab-panel-card__photos {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
  margin-top: var(--space-2);
}

@media (min-width: 576px) {
  .tab-panel-card__photos {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-5);
  }
}

.tab-photo-wrapper {
  width: 100%;
  aspect-ratio: 4 / 3;
  border-radius: var(--radius-2xl);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-stone-100);
}

.tab-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}

.tab-photo-wrapper:hover .tab-photo {
  transform: scale(1.04);
}

/* Accent Card Sidebar */
.accent-box--sidebar {
  margin-top: 0 !important;
  background: var(--color-green-wash);
  border: 1px solid rgba(88, 114, 77, 0.15);
  border-left: 5px solid var(--color-green);
  border-radius: var(--radius-2xl);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.accent-box--sidebar:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.accent-box__badge {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--color-green-dark);
  letter-spacing: 0.05em;
  margin-bottom: var(--space-2);
}

.accent-box__title {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-stone-800);
  margin-top: 0;
  margin-bottom: var(--space-4);
}

/* Stats Grid layout inside Tab 2 */
.stats-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}

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

@media (min-width: 768px) {
  .stats-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
  }
}

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

.stat-card {
  background: var(--color-bg-alt);
  border: 1px solid var(--color-stone-100);
  border-radius: var(--radius-2xl);
  padding: var(--space-6) var(--space-4);
  text-align: center;
  transition: transform var(--transition-base), box-shadow var(--transition-base), background-color var(--transition-base);
}

.stat-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  background: white;
  border-color: rgba(88, 114, 77, 0.2);
}

.stat-card__number {
  font-family: var(--font-serif);
  font-size: 2rem;
  font-weight: 700;
  color: var(--color-green);
  margin-bottom: var(--space-2);
}

@media (min-width: 768px) {
  .stat-card__number {
    font-size: 2.25rem;
  }
}

.stat-card__label {
  font-size: 0.75rem;
  color: var(--color-stone-600);
  line-height: 1.4;
  font-weight: 500;
}

/* Business/KSO layout and grid inside Tab 3 */
.accent-box--business {
  margin-top: 0 !important;
  margin-bottom: var(--space-6);
  border-left: 5px solid var(--color-green);
}

.business-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
  margin-top: var(--space-6);
}

@media (min-width: 768px) {
  .business-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
  }
}

.business-card {
  background: white;
  border: 1px solid var(--color-stone-100);
  border-radius: var(--radius-2xl);
  padding: var(--space-6) var(--space-5);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
}

.business-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: rgba(88, 114, 77, 0.2);
}

.business-card__icon-wrapper {
  width: 3rem;
  height: 3rem;
  background: var(--color-green-wash);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-green);
  margin-bottom: var(--space-5);
  flex-shrink: 0;
}

.business-card__icon-wrapper iconify-icon {
  font-size: 1.35rem;
  display: flex;
}

.business-card__title {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--color-stone-800);
  margin: 0 0 var(--space-3) 0;
  line-height: 1.3;
}

.business-card__text {
  font-size: 0.875rem;
  color: var(--color-stone-600);
  line-height: 1.6;
  margin: 0;
}

/* Photo Gallery Grid layout inside Tab 4 */
.gallery-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

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

.gallery-item {
  background: white;
  border-radius: var(--radius-2xl);
  overflow: hidden;
  border: 1px solid var(--color-stone-100);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.gallery-item:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}

.gallery-item__image-wrapper {
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: var(--color-stone-100);
}

.gallery-item__image-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}

.gallery-item:hover .gallery-item__image-wrapper img {
  transform: scale(1.04);
}

.gallery-item__caption {
  padding: var(--space-4) var(--space-5);
  font-size: 0.8125rem;
  color: var(--color-stone-700);
  line-height: 1.5;
  text-align: center;
  font-weight: 500;
  background: white;
  border-top: 1px solid var(--color-stone-100);
  flex-grow: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ======================================
   CAMPAIGN PROGRESS SECTION
   ====================================== */
.campaign {
  padding: var(--space-12) 0;
  position: relative;
  overflow: hidden;
  background: url('/assets/tmpl/actions/891/img/fon3.png') no-repeat center center;
  background-size: cover;
  border-bottom: 1px solid var(--color-green-mist);
}

@media (min-width: 768px) {
  .campaign {
    padding: var(--space-20) 0;
  }
}

/* Контейнер для летящих сердец */
#hearts-wrapper {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 1;
}

@keyframes floatUp {
  0% {
    transform: translateY(0) rotate(0deg);
    opacity: 0;
  }

  20% {
    opacity: 1;
  }

  100% {
    transform: translateY(-120vh) rotate(var(--end-rotate, 10deg));
    opacity: 0;
  }
}

.heart {
  position: absolute;
  color: rgba(88, 114, 77, 0.2);
  /* Элегантный полупрозрачный зелёный цвет по умолчанию */
  animation: floatUp linear infinite;
  z-index: 1;
  user-select: none;
  pointer-events: none;
  opacity: 0;
}

/* Карточка счётчика со светлым эффектом стекла */
.campaign__wrapper {
  position: relative;
  z-index: 10;
  background: rgba(255, 255, 255, 0.45);
  background: rgb(218 231 214 / 30%);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255, 255, 255, 0.6);
  border-radius: 2.5rem;
  padding: var(--space-10) var(--space-8);
  max-width: 69rem;
  /* Увеличено на 15% с 60rem */
  width: 100%;
  margin: 0 auto;
  box-shadow: var(--shadow-xl);
  transition: all 0.25s;
  text-align: center;
}

/* Верхняя плашка акции в Montserrat */
.campaign__badge {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--color-green);
  margin-bottom: var(--space-6);
  display: block;
}

/* Сетчатый симметричный заголовок (оригинальная стилистика) */
.campaign__top-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  align-items: center;
  margin-bottom: var(--space-8);
}

@media (min-width: 768px) {
  .campaign__top-row {
    grid-template-columns: 1fr 2fr 1fr;
    gap: var(--space-4);
  }
}

/* Колонки статистики */
.campaign__stat-col {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.campaign__stat-col--left {
  text-align: center;
}

.campaign__stat-col--right {
  text-align: center;
}

@media (min-width: 768px) {
  .campaign__stat-col--left {
    text-align: left;
  }

  .campaign__stat-col--right {
    text-align: right;
  }
}

.campaign__stat-label {
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-green);
  letter-spacing: 0.02em;
}

.campaign__stat-value {
  font-family: 'PT Serif', serif;
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--color-green);
  line-height: 1.1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

@media (min-width: 768px) {
  .campaign__stat-value {
    font-size: 3rem;
  }

  .campaign__stat-col--left .campaign__stat-value {
    justify-content: flex-start;
  }

  .campaign__stat-col--right .campaign__stat-value {
    justify-content: flex-end;
  }
}

.campaign__heart-icon {
  width: 0.91em;
  /* Точно того же размера, что и цифры */
  height: 1em;
  /* Точно того же размера, что и цифры */
  fill: none;
  stroke: var(--color-green);
  stroke-width: 1.3;
  /* Изящная тонкая линия */
  display: inline-block;
  vertical-align: middle;
  margin-left: 0.01rem;
  margin-top: -0.015rem;
  /* Выравнивание по центру относительно цифр */
}

/* Центральная брендовая колонка */
.campaign__center-col {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.campaign__title {
  font-family: var(--font-serif);
  font-size: 1.875rem;
  font-weight: 700;
  color: var(--color-green-dark);
  letter-spacing: 0.03em;
  margin-bottom: var(--space-1);
  line-height: 1.2;
}

@media (min-width: 768px) {
  .campaign__title {
    font-size: 2.25rem;
  }
}

.campaign__motto {
  font-family: var(--font-script);
  font-size: 2rem;
  color: var(--color-green);
  margin-bottom: 0;
  line-height: 1.3;
}

/* Панель шкалы прогресса */
.campaign__progress-panel {
  max-width: 66rem;
  /* Увеличено пропорционально с 48rem для расширенного виджета */
  margin: 0 auto var(--space-4);
}

/* Переоформление прогресс-бара с анимацией */
.progress-bar {
  position: relative;
}

.progress-bar__track {
  position: relative;
  background: #e6e8e3;
  border-radius: var(--radius-full);
  height: 1.75rem;
  overflow: hidden;
  border: none;
}

.progress-bar__fill {
  height: 100%;
  background: var(--color-green);
  /* Оригинальный зеленый цвет */
  border-radius: var(--radius-full);
  transition: width 1.5s var(--ease-out);
  position: relative;
  overflow: hidden;
}

.progress-bar__fill::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
  animation: shimmer 2.2s infinite;
}

@keyframes shimmer {
  0% {
    transform: translateX(-100%);
  }

  100% {
    transform: translateX(100%);
  }
}

/* Процент по центру прогресс-бара */
.progress-bar__text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-family: var(--font-sans);
  font-size: 0.8125rem;
  font-weight: 700;
  color: white;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);
  background: rgba(0, 0, 0, 0.2);
  padding: 2px 10px;
  border-radius: var(--radius-full);
  backdrop-filter: blur(2px);
  letter-spacing: 0.5px;
  z-index: 5;
  white-space: nowrap;
}

/* Метрика: осталось сердец */
.campaign__meta {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin: 8px 0 var(--space-8);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-stone-700);
  text-align: center;
}

.campaign__meta strong {
  color: var(--color-green);
  font-weight: 800;
}

/* CTA Область и оригинальная зеленая кнопка-пилюля */
.campaign__cta-area {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
  margin-top: var(--space-8);
}

.campaign__btn-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.625rem;
  background: var(--color-green);
  color: white !important;
  padding: 0.875rem 2.5rem;
  font-size: 1rem;
  font-weight: 500;
  border-radius: var(--radius-full);
  box-shadow: 0 4px 12px rgba(88, 114, 77, 0.15);
  transition: all var(--transition-base);
  width: 100%;
  max-width: 22rem;
  /* Увеличено для пропорционального удлинения кнопки */
}

.campaign__btn-submit:hover {
  background: var(--color-green-dark);
  color: white !important;
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(88, 114, 77, 0.25);
  text-decoration: none !important;
}

.campaign__btn-submit:active {
  transform: translateY(0) scale(0.98);
}

.campaign__btn-icon {
  font-size: 1.25rem;
  line-height: 1;
  font-weight: 300;
}

.campaign__caption {
  font-size: 0.875rem;
  color: var(--color-green);
  font-weight: 500;
  letter-spacing: 0.01em;
  margin-top: var(--space-2);
}

/* Donation form */
.donation-form-wrapper {
  display: none;
  background: rgba(245, 245, 244, 0.8);
  border-radius: var(--radius-2xl);
  padding: var(--space-6);
  border: 1px solid var(--color-stone-200);
  text-align: left;
  max-width: 40rem;
  margin: 0 auto;
  animation: scaleIn 0.3s var(--ease-out);
}

@media (min-width: 640px) {
  .donation-form-wrapper {
    padding: var(--space-8);
  }
}

.donation-form-wrapper.open {
  display: block;
}

.donation-form__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--color-stone-200);
  padding-bottom: var(--space-3);
  margin-bottom: var(--space-6);
}

.donation-form__header h3 {
  font-family: var(--font-serif);
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--color-green-deep);
}

.donation-form__cancel {
  color: var(--color-stone-400);
  font-size: 0.75rem;
  font-weight: 600;
  transition: color var(--transition-base);
}

.donation-form__cancel:hover {
  color: var(--color-stone-600);
}

/* Preset grid */
.presets-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.625rem;
  margin-bottom: var(--space-6);
}

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

.preset-btn {
  padding: 0.875rem 0.5rem;
  border-radius: var(--radius-xl);
  text-align: center;
  border: 2px solid var(--color-stone-200);
  background: white;
  color: var(--color-stone-700);
  transition: all var(--transition-base);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 5rem;
  overflow: hidden;
}

.preset-btn:hover {
  border-color: var(--color-stone-400);
}

.preset-btn.selected {
  background: var(--color-green-mist);
  border-color: var(--color-green);
  color: var(--color-green-deep);
}

.preset-btn__amount {
  font-family: var(--font-mono);
  font-size: 0.875rem;
  font-weight: 700;
}

.preset-btn__label {
  font-size: 0.5625rem;
  color: var(--color-stone-500);
  font-weight: 500;
  letter-spacing: -0.01em;
  line-height: 1.3;
}

/* Form inputs */
.form-group {
  margin-bottom: var(--space-6);
}

.form-group label {
  display: block;
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--color-stone-600);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: var(--space-2);
}

.form-input {
  width: 100%;
  background: white;
  border: 1px solid var(--color-stone-300);
  border-radius: var(--radius-xl);
  padding: 0.75rem 1rem;
  font-family: var(--font-mono);
  font-size: 0.875rem;
  color: var(--color-stone-800);
  transition: border-color var(--transition-base), box-shadow var(--transition-base);
  letter-spacing: 0.02em;
  outline: none;
}

.form-input::placeholder {
  color: var(--color-stone-400);
  font-family: var(--font-sans);
}

.form-input:focus {
  border-color: var(--color-green);
  box-shadow: 0 0 0 3px rgba(94, 121, 84, 0.15);
}

.form-input--text {
  font-family: var(--font-sans);
}

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

@media (min-width: 640px) {
  .form-row {
    grid-template-columns: 1fr 1fr;
  }
}

.input-wrap {
  position: relative;
}

.input-wrap__suffix {
  position: absolute;
  right: 1rem;
  top: 50%;
  transform: translateY(-50%);
  font-family: var(--font-mono);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-stone-400);
}

/* Error message */
.form-error {
  display: none;
  align-items: center;
  gap: var(--space-2);
  font-size: 0.75rem;
  font-weight: 500;
  color: #dc2626;
  background: #fef2f2;
  padding: 0.875rem;
  border-radius: var(--radius-xl);
  border: 1px solid #fee2e2;
  margin-bottom: var(--space-4);
}

.form-error.visible {
  display: flex;
}

.form-error svg {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
}

/* Submit row */
.form-submit-row {
  padding-top: var(--space-2);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  align-items: stretch;
}

@media (min-width: 640px) {
  .form-submit-row {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
}

.form-legal {
  font-size: 0.625rem;
  color: var(--color-stone-400);
  line-height: 1.5;
  max-width: 24rem;
}

/* Success state */
.donation-success {
  display: none;
  text-align: center;
  padding: var(--space-6) 0;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
  animation: scaleIn 0.4s var(--ease-out);
}

.donation-success.visible {
  display: flex;
}

.success-icon {
  width: 4rem;
  height: 4rem;
  background: var(--color-bg-alt);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-green);
}

.success-icon svg {
  width: 2rem;
  height: 2rem;
  stroke-width: 3;
}

.success-title {
  font-family: var(--font-serif);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-green-deep);
}

.success-text {
  font-size: 0.875rem;
  color: var(--color-stone-600);
  max-width: 28rem;
  line-height: 1.6;
}

.success-amount {
  display: inline-block;
  background: white;
  padding: 0.75rem 1.25rem;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xs);
  border: 1px solid var(--color-stone-100);
}

.success-amount__label {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--color-stone-500);
  font-weight: 500;
}

.success-amount__value {
  font-family: var(--font-mono);
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-green);
  margin-left: var(--space-2);
}

/* Spinner */
.spinner {
  display: inline-block;
  width: 1rem;
  height: 1rem;
  border: 2px solid rgba(255, 255, 255, 0.3);
  border-top-color: white;
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}

/* ======================================
   ABOUT CAMPAIGN SECTION
   ====================================== */
.about-campaign {
  padding: var(--space-16) 0;
  background: var(--color-bg-card);
  border-bottom: 1px solid var(--color-stone-200);
}

@media (min-width: 640px) {
  .about-campaign {
    padding: var(--space-24) 0;
  }
}

.about-campaign__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
  align-items: center;
}

@media (min-width: 1024px) {
  .about-campaign__grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-16);
  }
}

.about-campaign__text h2 {
  font-family: var(--font-serif);
  font-size: 1.875rem;
  font-weight: 700;
  color: var(--color-green-deep);
  line-height: 1.2;
  margin-bottom: var(--space-4);
}

@media (min-width: 640px) {
  .about-campaign__text h2 {
    font-size: 2.25rem;
  }
}

@media (min-width: 1024px) {
  .about-campaign__text h2 {
    font-size: 3rem;
  }
}

.about-campaign__text .section-heading__line {
  margin: 0 0 var(--space-6) 0;
}

.about-campaign__text p {
  color: var(--color-stone-600);
  line-height: 1.7;
  margin-bottom: var(--space-4);
}

.about-campaign__text p:last-of-type {
  font-size: 0.875rem;
  color: var(--color-stone-500);
}

.about-campaign__visual {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  align-items: center;
}

@media (min-width: 640px) {
  .about-campaign__visual {
    grid-template-columns: 1fr 1fr;
  }
}

.about-campaign__image {
  position: relative;
  aspect-ratio: 1;
  border-radius: 2.2rem;
  overflow: hidden;
  box-shadow: var(--shadow-xl);
  border: 4px solid var(--color-stone-50);
}

.about-campaign__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.about-campaign__image-overlay {
  position: absolute;
  inset: 0;
  background: rgba(6, 78, 59, 0.05);
  mix-blend-mode: multiply;
}

.about-campaign__thanks {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
  text-align: center;
  padding: 0 var(--space-4);
}

@media (min-width: 640px) {
  .about-campaign__thanks {
    align-items: flex-start;
    text-align: left;
  }
}

.about-campaign__thanks-text {
  font-family: var(--font-script);
  font-size: 2.5rem;
  color: var(--color-green-deep);
  line-height: 1.15;
  user-select: none;
}

@media (min-width: 640px) {
  .about-campaign__thanks-text {
    font-size: 3rem;
  }
}

.about-campaign__thanks-heart {
  width: 9rem;
  height: 3rem;
  color: rgba(94, 121, 84, 0.5);
}

/* ======================================
   HOW TO HELP SECTION
   ====================================== */
.how-to-help {
  padding: var(--space-16) 0 var(--space-8) 0;
  background: url('/assets/tmpl/actions/891/img/lug.png') no-repeat center/cover;
  position: relative;
  border-bottom: 1px solid var(--color-green-mist);
}

.how-to-help .section-heading--backdrop .section-heading__title {
  background: transparent;
}

@media (min-width: 640px) {
  .how-to-help {
    padding: var(--space-24) 0 var(--space-12) 0;
  }
}

.how-to-help__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.75rem var(--space-5);
  align-items: stretch;
  margin-top: 2.75rem;
}

@media (min-width: 768px) {
  .how-to-help__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .how-to-help__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
  }
}

.help-card {
  position: relative;
  /* Glassmorphism — same style as quote block */
  background: rgba(255, 255, 255, 0.82);
  backdrop-filter: blur(3px) saturate(1.3);
  -webkit-backdrop-filter: blur(14px) saturate(1.3);
  border-radius: var(--radius-xl);
  padding: 2.75rem var(--space-5) var(--space-5) var(--space-5);
  border: 1px solid rgba(255, 255, 255, 0.6);
  box-shadow: 0 8px 32px rgba(63, 95, 59, 0.10), 0 1.5px 6px rgba(63, 95, 59, 0.07);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  cursor: pointer;
  text-align: center;
  transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base), background var(--transition-base);
  box-sizing: border-box;

}

.help-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 40px rgba(63, 95, 59, 0.15), 0 4px 10px rgba(63, 95, 59, 0.08);
  border-color: rgba(88, 114, 77, 0.45);
  background: rgba(255, 255, 255, 0.92);
}

/* Corner Heart from Reference 1 */
.help-card__heart {
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 1.05rem;
  height: 1.05rem;
  color: var(--color-green-mist);
  opacity: 0.85;
  transition: transform var(--transition-base), color var(--transition-base);
}

.help-card:hover .help-card__heart {
  color: var(--color-green-soft);
  transform: scale(1.18) rotate(8deg);
}

/* Overlapping Centered Icon Badge from Reference 2 - shrunk by 15% */
.help-card__icon-badge {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 3.85rem;
  height: 3.85rem;
  border-radius: 50%;
  background: var(--color-stone-50);
  border: 2px solid var(--color-green-pale);
  box-shadow: var(--shadow-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-base);
  z-index: 2;
}

.help-card:hover .help-card__icon-badge {
  background: var(--color-green-wash);
  border-color: var(--color-green);
  box-shadow: var(--shadow-md);
  transform: translate(-50%, -55%);
}

.help-card__icon-badge iconify-icon {
  font-size: 1.85rem;
  color: var(--color-green);
  transition: transform var(--transition-base), color var(--transition-base);
  display: flex;
  align-items: center;
  justify-content: center;
}

.help-card:hover .help-card__icon-badge iconify-icon {
  color: var(--color-green-dark);
  transform: scale(1.08);
}

.help-card__content {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  flex-grow: 1;
  margin-bottom: var(--space-3);
}

/* Card titles with elegant serif font from Reference 2 - shrunk by 15% */
.help-card__title {
  font-family: var(--font-serif);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--color-stone-700);
  margin-top: 0.5rem;
  margin-bottom: var(--space-2) !important;
  transition: color var(--transition-base);
}

.help-card:hover .help-card__title {
  color: var(--color-green);
}

.help-card__desc {
  font-size: 0.8rem;
  color: var(--color-stone-600);
  line-height: 1.5;
  font-weight: 400;
}

/* Action button wrapper & sleek pill buttons from Reference 2 - shrunk by 15% */
.help-card__btn-wrapper {
  display: flex;
  justify-content: center;
  margin-top: auto;
  padding-top: var(--space-2);
  width: 100%;
}

.help-card__btn-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  padding: 0.4rem 1.25rem;
  border-radius: var(--radius-full);
  border: 1px solid var(--color-green-pale);
  background: var(--color-stone-50);
  color: var(--color-stone-600);
  font-size: 0.8rem;
  font-weight: 600;
  transition: all var(--transition-base);
  box-shadow: var(--shadow-sm);
  box-sizing: border-box;
}

.help-card:hover .help-card__btn-pill {
  background: var(--color-green);
  color: var(--color-bg) !important;
  border-color: var(--color-green-dark);
  box-shadow: var(--shadow-md);
}

.btn-pill__arrow {
  font-size: 0.9rem;
  transition: transform var(--transition-base);
}

.help-card:hover .btn-pill__arrow {
  transform: translateX(4px);
}

/* Share buttons inside "Словом" card with outline green pills from Reference 1 - brand colored */
.share-buttons {
  width: 100%;
  margin-top: auto;
  padding-top: var(--space-3);
  border-top: 1px solid rgba(88, 114, 77, 0.08);
}

.share-buttons__list {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  width: 100%;
}

.share-buttons__label {
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--color-stone-400);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  line-height: 1;
  width: 100%;
  text-align: center;
  margin-bottom: 0.25rem;
}

.share-btn-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
  height: 1.65rem;
  padding: 0 0.65rem;
  border-radius: 1rem;
  border: 1px solid transparent;
  font-size: 0.7rem;
  font-weight: 600;
  transition: all var(--transition-base);
  box-shadow: var(--shadow-xs);
  box-sizing: border-box;
}

.share-btn-pill iconify-icon {
  font-size: 0.9rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.share-btn-pill span {
  line-height: 1;
}

/* VK brand styling */
.share-btn-pill--vk {
  background: rgba(74, 118, 168, 0.09);
  color: #4A76A8;
}

.share-btn-pill--vk iconify-icon {
  color: #4A76A8;
}

.share-btn-pill--vk:hover {
  background: #4A76A8 !important;
  border-color: #4A76A8 !important;
  color: #ffffff !important;
  transform: translateY(-2px);
  box-shadow: var(--shadow-sm);
}

.share-btn-pill--vk:hover iconify-icon {
  color: #ffffff !important;
}

/* Telegram brand styling */
.share-btn-pill--tg {
  background: rgba(0, 136, 204, 0.09);
  color: #0088cc;
}

.share-btn-pill--tg iconify-icon {
  color: #0088cc;
}

.share-btn-pill--tg:hover {
  background: #0088cc !important;
  border-color: #0088cc !important;
  color: #ffffff !important;
  transform: translateY(-2px);
  box-shadow: var(--shadow-sm);
}

.share-btn-pill--tg:hover iconify-icon {
  color: #ffffff !important;
}

/* WhatsApp brand styling */
.share-btn-pill--wa {
  background: rgba(37, 211, 102, 0.09);
  color: #25D366;
}

.share-btn-pill--wa iconify-icon {
  color: #25D366;
}

.share-btn-pill--wa:hover {
  background: #25D366 !important;
  border-color: #25D366 !important;
  color: #ffffff !important;
  transform: translateY(-2px);
  box-shadow: var(--shadow-sm);
}

.share-btn-pill--wa:hover iconify-icon {
  color: #ffffff !important;
}

.share-btn-pill:active {
  transform: scale(0.96);
}

/* Quote at the bottom of the section with glassmorphism backdrop for readability */
.how-to-help__quote-wrap {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  width: fit-content;
  max-width: 94%;
  margin: 3.5rem auto 0;

  /* Glassmorphism effect for readability over lug.png */
  background: rgba(255, 255, 255, 0.72);
  backdrop-filter: blur(14px) saturate(1.4);
  -webkit-backdrop-filter: blur(14px) saturate(1.4);
  border: 1px solid rgba(255, 255, 255, 0.55);
  border-radius: var(--radius-2xl);
  padding: var(--space-5) var(--space-8);
  box-shadow: 0 8px 32px rgba(63, 95, 59, 0.10), 0 1.5px 6px rgba(63, 95, 59, 0.07);
}


.how-to-help__quote {
  font-family: var(--font-script);
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--color-green-dark);
  line-height: 1.35;
  margin-bottom: 0 !important;
  flex-shrink: 0;
  /* Subtle text shadow for extra contrast */
  text-shadow: 0 1px 8px rgba(255, 255, 255, 0.7), 0 0 2px rgba(255, 255, 255, 0.4);
}



.how-to-help__quote-heart {
  width: 2.5rem;
  height: 2.5rem;
  color: var(--color-green);
  opacity: 0.9;
  flex-shrink: 0;
  filter: drop-shadow(0 2px 6px rgba(88, 114, 77, 0.3));
  animation: heartPulse 2.5s infinite ease-in-out;
}


/* ======================================
   STORIES SECTION
   ====================================== */
.stories {
  padding: var(--space-16) 0;
  background: var(--color-bg-card);
  border-bottom: 1px solid var(--color-stone-200);
}

@media (min-width: 640px) {
  .stories {
    padding: var(--space-24) 0;
  }
}

.stories .section-heading .campaign__sub {
  margin-bottom: var(--space-2);
}

.stories__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
}

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

.story-card {
  background: var(--color-stone-50);
  border-radius: var(--radius-3xl);
  padding: var(--space-8);
  border: 1px solid var(--color-stone-100);
  box-shadow: var(--shadow-xs);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  text-align: left;
  position: relative;
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.story-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-md);
}

.story-card__quote-icon {
  position: absolute;
  top: 1.5rem;
  right: 2rem;
  color: rgba(214, 211, 209, 0.5);
  pointer-events: none;
  user-select: none;
}

.story-card__quote-icon svg {
  width: 2.5rem;
  height: 2.5rem;
  fill: currentColor;
}

.story-card__text {
  font-size: 0.875rem;
  color: var(--color-stone-600);
  line-height: 1.7;
  font-style: italic;
}

@media (min-width: 640px) {
  .story-card__text {
    font-size: 0.9375rem;
  }
}

.story-card__footer {
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-stone-200);
  margin-top: var(--space-6);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.story-card__author {
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--color-green-deep);
}

.story-card__relation {
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--color-green-soft);
}

.story-card__date {
  font-family: var(--font-mono);
  font-size: 0.625rem;
  color: var(--color-stone-400);
  font-weight: 500;
  letter-spacing: 0.05em;
}

/* ======================================
   FOOTER — Compact Reference Design
   ====================================== */
.site-footer {
  /* ──── Настройки для ручной регулировки расположения текста ──── */
  --footer-compact-left-shift: clamp(230px, 33vw, 230px); /* Сдвиг всего верхнего ряда вправо (чтобы обойти рисунок) */
  --brand-vertical-shift: 0px;    /* Смещение блока бренда вверх/вниз (например: 15px сдвинет вниз, -10px сдвинет вверх) */
  --brand-alignment: flex-start;  /* Выравнивание блока: flex-start (влево), center (по центру), flex-end (вправо) */
  --brand-text-align: left;       /* Выравнивание строк текста: left, center, right */
  --brand-gap: 0.1rem;            /* Расстояние между строкой "Тверской хоспис" и "«Анастасия»" */
  
  /* Шрифты и размеры для "Тверской хоспис" */
  --brand-label-size: 0.8rem;
  --brand-label-weight: 500;
  --brand-label-letter-spacing: 0.03em;
  --brand-label-line-height: 1.2;
  
  /* Шрифты и размеры для "«Анастасия»" */
  --brand-name-size: 1.25rem;
  --brand-name-weight: 700;
  --brand-name-line-height: 1.1;
  /* ───────────────────────────────────────────────────────────── */

  background-color: #f7f9f6;
  /* Very soft light watercolor green-grey wash */
  background-image: url('/assets/tmpl/actions/891/img/botom4.png');
  background-repeat: no-repeat;
  background-position: center top;
  background-size: 100% auto;
  position: relative;
  overflow: hidden;
}

/* ── Compact single-row footer bar ── */
.footer__compact {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  min-height: 120px;
  position: relative;
  z-index: 1;
  max-width: 80rem;
  margin: 0 auto;
 padding: 3.1rem var(--space-10) 0rem var(--footer-compact-left-shift);
  gap: var(--space-6);
}

/* Brand block */
.footer__brand-block {
  display: flex;
  flex-direction: column;
  align-items: var(--brand-alignment);
  text-align: var(--brand-text-align);
  gap: var(--brand-gap);
  transform: translateY(var(--brand-vertical-shift)); /* Вертикальный сдвиг текста */
  flex-shrink: 0;
}

.footer__brand-label {
  font-family: var(--font-sans);
  font-size: var(--brand-label-size);
  font-weight: var(--brand-label-weight);
  color: var(--color-green-deep);
  /* Green label */
  letter-spacing: var(--brand-label-letter-spacing);
  line-height: var(--brand-label-line-height);
}

.footer__brand-name {
  font-family: var(--font-serif);
  font-size: var(--brand-name-size);
  font-weight: var(--brand-name-weight);
  color: var(--color-green-deep);
  /* Green name */
  line-height: var(--brand-name-line-height);
}

/* Social icon row */
.footer__socials-row {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  flex-shrink: 0;
}

.footer__soc-btn {
  width: 2.2rem;
  height: 2.2rem;
  border-radius: 50%;
  background: transparent;
  border: 1.5px solid var(--color-green-deep);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-green-deep);
  /* Green icon */
  font-size: 1.15rem;
  transition: all var(--transition-base);
}

.footer__soc-btn:hover {
  transform: translateY(-3px);
  background: var(--color-green-deep);
  color: white !important;
  border-color: var(--color-green-deep);
  box-shadow: 0 4px 10px rgba(88, 114, 77, 0.2);
}

.footer__soc-btn--vk:hover {
  color: white !important;
  border-color: var(--color-green-deep) !important;
}

.footer__soc-btn--tg:hover {
  color: white !important;
  border-color: var(--color-green-deep) !important;
}

.footer__soc-btn--ok:hover {
  color: white !important;
  border-color: var(--color-green-deep) !important;
}

/* Contacts block */
.footer__contacts {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.2rem;
  flex-shrink: 0;
}

.footer__phone {
  font-family: var(--font-sans);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--color-green-deep);
  /* Green phone */
  transition: color var(--transition-base);
  white-space: nowrap;
}

.footer__phone:hover {
  color: var(--color-green-dark);
}

.footer__email {
  font-size: 0.8rem;
  color: var(--color-green-deep);
  /* Green email */
  font-weight: 500;
  transition: color var(--transition-base);
}

.footer__email:hover {
  color: var(--color-green-dark);
  text-decoration: underline;
}

/* Support button */
.footer__support-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.75rem 2rem;
  border-radius: var(--radius-full);
  border: 1.5px solid var(--color-green-deep);
  /* Green border in normal state */
  background: transparent;
  color: var(--color-green-deep);
  /* Green text in normal state */
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition-base);
  white-space: nowrap;
  flex-shrink: 0;
}

.footer__support-btn:hover {
  border-color: var(--color-green-deep);
  color: white !important;
  /* White text on hover */
  background: var(--color-green-deep);
  /* Solid green background on hover */
  box-shadow: var(--shadow-md);
}

.footer__support-icon {
  font-size: 0.95rem;
  color: currentColor;
}

/* Bottom info bar (address & requisites) */
.footer__bottom-info {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  color: #2a3d24; /* Dark rich green for maximum contrast on watercolor background */
  max-width: 80rem;
  margin: 0 auto;
  padding: 1rem var(--space-10) 1.5rem var(--space-10); /* Full length of the container block */
  gap: var(--space-4);
  position: relative;
  z-index: 1;
}

.footer__legal-text {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  line-height: 1.5;
  text-align: center;
}

.footer__info-separator {
  margin: 0 0.5rem;
  color: rgba(88, 114, 77, 0.4);
  font-weight: bold;
  user-select: none;
}

.footer__info-icon {
  font-size: 0.95rem;
  color: #2a3d24; /* Dark rich green */
  flex-shrink: 0;
}

/* ── Responsive: stacked layout on mobile ── */
@media (max-width: 767px) {
  .footer__compact {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 1.5rem var(--space-4) 2rem var(--space-4) !important;
    padding-top: calc(min(45vw, 150px) + 1rem) !important;
    gap: var(--space-5);
    text-align: center;
  }

  .footer__brand-block {
    align-items: center;
  }

  .footer__contacts {
    align-items: center;
  }

  .footer__bottom-info {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.6rem;
    padding: 1rem var(--space-4) 1.5rem var(--space-4) !important;
  }

  .footer__legal-text {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.6rem;
  }

  .footer__info-separator {
    display: none;
  }
}

/* ── keep old social-btn class working (used elsewhere) ── */
.social-btn {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  background: white;
  border: 1px solid var(--color-stone-200);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  color: var(--color-stone-600);
  box-shadow: var(--shadow-xs);
  transition: all var(--transition-base);
}

.social-btn:hover {
  transform: scale(1.05);
}

.social-btn:active {
  transform: scale(0.95);
}

.social-btn--vk:hover {
  color: #4A76A8;
  border-color: #b3d1f2;
}

.social-btn--tg:hover {
  color: #0088cc;
  border-color: #a8d8ea;
}

.social-btn--ok:hover {
  color: #ee8208;
  border-color: #fdd49e;
}

/* ======================================
   MODAL (Volunteer)
   ====================================== */
.modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 50;
  display: none;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  overflow-y: auto;
}

.modal-overlay.open {
  display: flex;
}

.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  animation: fadeIn 0.2s ease;
}

.modal-body {
  background: var(--color-bg);
  border-radius: var(--radius-3xl);
  box-shadow: var(--shadow-xl);
  position: relative;
  max-width: 36rem;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  z-index: 10;
  border: 1px solid var(--color-stone-100);
  animation: scaleIn 0.3s var(--ease-out);
}

.modal-header {
  position: sticky;
  top: 0;
  padding: var(--space-5);
  background: rgba(250, 249, 245, 0.9);
  backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--color-stone-200);
  z-index: 10;
}

.modal-header__title {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.modal-header__title svg {
  width: 1.25rem;
  height: 1.25rem;
  color: var(--color-green);
}

.modal-header__title h3 {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-green-deep);
}

.modal-close {
  padding: 0.375rem;
  border-radius: 50%;
  background: white;
  color: var(--color-stone-400);
  transition: all var(--transition-base);
}

.modal-close:hover {
  color: var(--color-stone-700);
  background: var(--color-stone-100);
}

.modal-close svg {
  width: 1.25rem;
  height: 1.25rem;
}

.modal-content {
  padding: var(--space-6);
}

@media (min-width: 640px) {
  .modal-content {
    padding: var(--space-8);
  }
}

.modal-content>p {
  font-size: 0.8125rem;
  color: var(--color-stone-500);
  line-height: 1.6;
  margin-bottom: var(--space-6);
}

/* Interest tags */
.interests-label {
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--color-stone-600);
  text-transform: uppercase;
  margin-bottom: var(--space-2);
}

.interests-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}

.interest-tag {
  padding: 0.375rem 0.75rem;
  border-radius: var(--radius-md);
  font-size: 0.75rem;
  font-weight: 500;
  border: 1px solid var(--color-stone-200);
  background: white;
  color: var(--color-stone-600);
  transition: all var(--transition-base);
}

.interest-tag:hover {
  border-color: var(--color-stone-400);
}

.interest-tag.selected {
  background: var(--color-green-mist);
  border-color: var(--color-green);
  color: var(--color-green-deep);
}

.modal-form textarea {
  resize: vertical;
  min-height: 4rem;
}

.modal-actions {
  border-top: 1px solid var(--color-stone-200);
  padding-top: var(--space-5);
  margin-top: var(--space-6);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-3);
}

.btn--ghost {
  padding: 0.625rem var(--space-6);
  border-radius: var(--radius-xl);
  color: var(--color-stone-500);
  font-weight: 600;
  font-size: 0.875rem;
  transition: background var(--transition-base);
}

.btn--ghost:hover {
  background: var(--color-stone-100);
}

.btn--submit {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: var(--color-green);
  color: white;
  padding: 0.625rem 1.75rem;
  border-radius: var(--radius-xl);
  font-weight: 600;
  font-size: 0.875rem;
  box-shadow: var(--shadow-sm);
  transition: all var(--transition-base);
}

.btn--submit:hover {
  background: var(--color-green-dark);
}

.btn--submit:active {
  transform: scale(0.98);
}

.btn--submit:disabled {
  background: var(--color-stone-300);
  cursor: not-allowed;
}

.btn--submit svg {
  width: 1rem;
  height: 1rem;
}

/* Modal success */
.modal-success {
  display: none;
  text-align: center;
  padding: var(--space-8) 0;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
  animation: scaleIn 0.4s var(--ease-out);
}

.modal-success.visible {
  display: flex;
}

/* ======================================
   DRAWER (Supplies / Spread)
   ====================================== */
.drawer-overlay {
  position: fixed;
  inset: 0;
  z-index: 50;
  overflow: hidden;
  display: none;
  justify-content: flex-end;
}

.drawer-overlay.open {
  display: flex;
}

.drawer-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  cursor: pointer;
  animation: fadeIn 0.2s ease;
}

.drawer-panel {
  position: relative;
  width: 100%;
  max-width: 28rem;
  background: var(--color-bg);
  box-shadow: var(--shadow-xl);
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  overflow-y: auto;
  border-left: 1px solid var(--color-stone-200);
  animation: slideInRight 0.35s var(--ease-out);
}

.drawer-header {
  padding: var(--space-6);
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--color-stone-200);
  background: white;
}

@media (min-width: 640px) {
  .drawer-header {
    padding: var(--space-8);
  }
}

.drawer-header h3 {
  font-family: var(--font-serif);
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--color-green-deep);
}

.drawer-close {
  padding: 0.375rem;
  border-radius: 50%;
  background: var(--color-stone-100);
  color: var(--color-stone-500);
  transition: color var(--transition-base);
}

.drawer-close:hover {
  color: var(--color-stone-800);
}

.drawer-close svg {
  width: 1.25rem;
  height: 1.25rem;
}

.drawer-body {
  padding: var(--space-6);
  flex: 1;
  overflow-y: auto;
}

@media (min-width: 640px) {
  .drawer-body {
    padding: var(--space-8);
  }
}

.drawer-body>p {
  font-size: 0.875rem;
  color: var(--color-stone-500);
  line-height: 1.6;
  margin-bottom: var(--space-6);
}

.supplies-list {
  background: white;
  padding: var(--space-5);
  border-radius: var(--radius-2xl);
  border: 1px solid var(--color-stone-100);
  box-shadow: var(--shadow-xs);
  margin-bottom: var(--space-6);
}

.supplies-list h4 {
  font-size: 0.6875rem;
  font-weight: 700;
  color: var(--color-stone-600);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: var(--space-3);
}

.supplies-list li {
  display: flex;
  align-items: flex-start;
  gap: 0.625rem;
  font-size: 0.8125rem;
  color: var(--color-stone-700);
  font-weight: 500;
  margin-bottom: 0.625rem;
}

.supplies-list li:last-child {
  margin-bottom: 0;
}

.supplies-check {
  width: 1.25rem;
  height: 1.25rem;
  border-radius: 50%;
  background: var(--color-green-wash);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-green);
  flex-shrink: 0;
  margin-top: 2px;
}

.supplies-check svg {
  width: 0.75rem;
  height: 0.75rem;
  stroke-width: 3;
}

.supplies-contact {
  padding: var(--space-4);
  background: var(--color-bg-alt);
  border-radius: var(--radius-2xl);
  border: 1px solid #D5E1CE;
}

.supplies-contact span {
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--color-green-deep);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  display: block;
  margin-bottom: var(--space-1);
}

.supplies-contact p {
  font-size: 0.75rem;
  color: #4D6444;
  line-height: 1.6;
}

/* Share buttons */
.share-btn {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: white;
  border: 1px solid var(--color-stone-200);
  padding: 1.125rem;
  border-radius: var(--radius-2xl);
  transition: border-color var(--transition-base);
  margin-bottom: var(--space-4);
}

.share-btn:hover {
  border-color: var(--color-stone-400);
}

.share-btn__left {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.share-btn__icon {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: var(--radius-xl);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 0.75rem;
}

.share-btn__icon--copy {
  background: var(--color-green-mist);
  color: var(--color-green);
}

.share-btn__icon--vk {
  background: #eff6ff;
  color: #2563eb;
}

.share-btn__icon--tg {
  background: #f0f9ff;
  color: #0ea5e9;
}

.share-btn__icon svg {
  width: 1rem;
  height: 1rem;
}

.share-btn__info {
  text-align: left;
}

.share-btn__title {
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--color-green-deep);
}

.share-btn__sub {
  font-size: 0.625rem;
  color: var(--color-stone-500);
  font-weight: 300;
}

.share-btn__label {
  font-size: 0.625rem;
  font-weight: 600;
  color: var(--color-stone-400);
  text-transform: uppercase;
  transition: color var(--transition-base);
}

.share-btn:hover .share-btn__label {
  color: var(--color-stone-700);
}

.share-btn__copied {
  display: none;
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--color-green);
  background: var(--color-green-wash);
  padding: 0.25rem 0.5rem;
  border-radius: var(--radius-sm);
}

.drawer-footer {
  padding: var(--space-6);
  background: white;
  border-top: 1px solid var(--color-stone-200);
}

.drawer-footer .btn--primary {
  width: 100%;
  border-radius: var(--radius-xl);
  font-size: 0.875rem;
}

/* Input with icon prefix */
.input-icon-wrap {
  position: relative;
}

.input-icon-wrap svg {
  position: absolute;
  left: 0.875rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1rem;
  height: 1rem;
  color: var(--color-stone-400);
}

.input-icon-wrap .form-input {
  padding-left: 2.5rem;
}

/* ======================================
   UIKIT PREMIUM CUSTOM OVERRIDES
   ====================================== */
.uk-modal-dialog {
  border-radius: var(--radius-3xl) !important;
  background: var(--color-bg) !important;
  border: 1px solid var(--color-stone-100) !important;
  box-shadow: var(--shadow-xl) !important;
  overflow: hidden;
  padding: 0 !important;
}

.uk-modal-header {
  background: rgba(244, 247, 253, 0.95) !important;
  border-bottom: 1px solid var(--color-stone-200) !important;
  padding: var(--space-5) var(--space-6) !important;
}

.uk-modal-footer {
  border-top: 1px solid var(--color-stone-200) !important;
  background: var(--color-bg) !important;
  padding: var(--space-5) var(--space-6) !important;
}

.uk-offcanvas-bar {
  background: var(--color-bg) !important;
  color: var(--color-stone-800) !important;
  width: 100% !important;
  max-width: 28rem !important;
  box-shadow: var(--shadow-xl) !important;
  border-left: 1px solid var(--color-stone-200) !important;
  padding: 0 !important;
}

/* ======================================
   EVENT PROGRAM SECTION
   ====================================== */
.program {
  padding: var(--space-12) 0 var(--space-2) 0;
  /* Reduced bottom padding by another 50% to bring partners even closer */
  background: var(--color-bg);
  position: relative;
  overflow: hidden;
}

@media (min-width: 1024px) {
  .program {
    padding: var(--space-16) 0 var(--space-3) 0;
    /* Reduced bottom padding by another 50% to bring partners even closer */
  }
}

.section-heading--program {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, calc(-50% - 8px));
  /* Centered horizontally and vertically, plus raised by 8px */
  background: var(--color-bg);
  /* Snug white background mask matching the section background */
  padding: 0 var(--space-4);
  /* Creates a beautiful gap on the sides of the text */
  z-index: 10;
  white-space: nowrap;
  line-height: 1;
}

.section-heading--program .section-heading__title {
  display: inline-block;
  margin: 0;
  font-size: 1.5rem;
  vertical-align: middle;
  color: var(--color-green-deep);
}

@media (min-width: 640px) {
  .section-heading--program .section-heading__title {
    font-size: 1.75rem;
  }
}

.section-heading--program .section-heading__title-wrap {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  max-width: 100%;
  vertical-align: middle;
}

.program-heading-decor {
  /* ==========================================================================
     РУЧНАЯ НАСТРОЙКА ИКОНКИ (СЕРДЕЧКА)
     Вы можете менять эти переменные прямо здесь для тонкой регулировки:
     ========================================================================== */
  --decor-size: 66px;
  /* Размер иконки (и высота, и ширина) */
  --decor-vertical-shift: -3px;
  /* Сдвиг по вертикали (например: -4px чтобы поднять, 4px чтобы опустить) */
  --decor-horizontal-shift: 5px;
  /* Сдвиг по горизонтали (например: -5px чтобы сдвинуть влево, 5px вправо) */

  /* Применение настроек */
  height: var(--decor-size);
  width: var(--decor-size);
  transform: translate(var(--decor-horizontal-shift), var(--decor-vertical-shift));

  /* Системные стили */
  display: inline-block;
  vertical-align: middle;
  object-fit: contain;
  flex-shrink: 0;
}

/* Card Container */
.program__card {
  /*   background: #f4f7f38a;*/
  border: 1px solid var(--color-green-deep);
  /* Native 1px green border on all sides for perfect corners */
  border-radius: var(--radius-3xl);
  box-shadow: var(--shadow-md);
  padding: var(--space-5);
  /* Compressed card padding (20px instead of 24px) */
  position: relative;
  margin-top: var(--space-6);
  /* Compressed margin-top (24px instead of 32px) */
  transition: box-shadow var(--transition-base);
}

.program__card:hover {
  box-shadow: var(--shadow-lg);
}

@media (min-width: 768px) {
  .program__card {
    padding: var(--space-8);
    /* Compressed tablet padding (32px instead of 40px) */
    padding-left: calc(220px + var(--space-8));
    /* Kept the custom 220px shift */
  }
}

@media (min-width: 1024px) {
  .program__card {
    padding: var(--space-10);
    /* Compressed desktop padding (40px instead of 48px) */
    padding-left: calc(220px + var(--space-10));
    /* Kept the custom 220px shift */
  }
}

/* Responsive Grid */
.program__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  align-items: center;
  position: relative;
  z-index: 2;
  /* places content on top of absolute background image */
}

@media (min-width: 768px) {
  .program__grid {
    grid-template-columns: 1.1fr 1.9fr;
    /* restore original columns layout */
    gap: var(--space-8);
  }
}

@media (min-width: 1024px) {
  .program__grid {
    grid-template-columns: 1.35fr 1.85fr;
    gap: var(--space-1);
  }
}

/* Left Column: Visual Gazebo spanning entire height as an absolute aligned background */
.program__visual {
  margin: -var(--space-5) -var(--space-5) var(--space-5) -var(--space-5);
  /* Adjusted to match card padding space-5 */
  border-top-left-radius: var(--radius-3xl);
  border-top-right-radius: var(--radius-3xl);
  overflow: hidden;
  display: block;
  height: 170px;
  /* Compressed mobile height (170px instead of 200px) */
  position: relative;
  z-index: 1;
}

.program__gazebo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s var(--ease-out);
}

.program__card:hover .program__gazebo {
  transform: scale(1.03);
}

@media (min-width: 768px) {
  .program__visual {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    width: 50%;
    /* spans 50% of the card to prevent image cropping and act as background behind the text */
    margin: 0;
    border-top-left-radius: var(--radius-3xl);
    border-bottom-left-radius: var(--radius-3xl);
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    overflow: hidden;
    display: block;
    height: 100%;
    z-index: 1;
    /* behind grid content */
  }

  .program__gazebo {
    height: 100%;
    width: auto;
    /* natural proportions, no stretch or zoom */
    object-fit: contain;
    object-position: left center;
  }
}

@media (min-width: 1024px) {
  .program__visual {
    width: 50%;
    /* spans 50% of the card to act as a background underneath the text column */
  }
}

/* Center Column: Text Content */
.program__info {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  text-align: left;
}

.program__title {
  font-family: var(--font-serif);
  font-size: 1.625rem;
  font-weight: 700;
  line-height: 1.25;
  color: var(--color-green-deep);
}

@media (min-width: 1024px) {
  .program__title {
    font-size: 1.3rem;
  }
}

.program__subtitle {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 0.9rem;
  color: var(--color-green);
  /* text-transform: uppercase; */
  letter-spacing: 0.05em;
  display: inline-block;
}

.program__text {
  margin-top: 4px;
  /* Отдельный отступ сверху для текста */
  font-size: 0.9375rem;
  color: var(--color-stone-600);
  line-height: 1.65;
}

/* Right Column: List and CTA placed side-by-side on desktop */
.program__action-block {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  position: relative;
  text-align: left;
}

@media (min-width: 1024px) {
  .program__action-block {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-8);
    padding-left: var(--space-6);
    border-left: 1px dashed var(--color-green-mist);
    height: 100%;
  }

  .program__participants {
    flex: 1;
    max-width: 65%;
  }

  .program__cta {
    flex-shrink: 0;
    width: 220px;
  }
}

/* Background floating music notes */
.program__music-notes {
  position: absolute;
  top: -10px;
  right: -5px;
  width: 80px;
  height: 80px;
  pointer-events: none;
  opacity: 0.15;
  color: var(--color-green);
}

.music-note {
  font-size: 2rem;
  position: absolute;
  animation: floatNotes 6s infinite ease-in-out;
}

.music-note--1 {
  top: 0;
  right: 0;
  font-size: 2.25rem;
  animation-delay: 0s;
}

.music-note--2 {
  bottom: 20px;
  left: 10px;
  font-size: 1.5rem;
  animation-delay: 3s;
}

@keyframes floatNotes {

  0%,
  100% {
    transform: translateY(0) rotate(0deg);
  }

  50% {
    transform: translateY(-8px) rotate(12deg);
  }
}

/* Participants List */
.program__participants {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  /* Tighter gap to raise list items higher */
  margin-top: -90px;
  /* Shifts the entire block slightly upwards as requested */
}

.program__list-title {
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--color-stone-700);
  /* text-transform: uppercase;  */
  letter-spacing: 0.05em;
}

.program__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  /* Increased distance between list items as requested */
  padding-left: 0;
  list-style: none;
}

.program__item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  /* Matches B2B partners gap for identical alignment */
  transition: transform var(--transition-base);
}

.program__item:hover {
  transform: translateX(4px);
}

.program__item-icon {
  color: var(--color-green-deep);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.35rem;
  /* Matches B2B partners icon size */
  width: 1.5rem;
  /* Ensures consistent alignment width */
  flex-shrink: 0;
}

.program__item-name {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-green-deep);
}

/* Artist CTA Button */
.btn--artist {
  background: var(--color-green-deep);
  color: white;
  width: 100%;
  padding: 0.875rem var(--space-6);
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-sm);
  transition: all var(--transition-base);
  /* text-transform: uppercase; */
}

.btn--artist:hover {
  background: var(--color-green-dark);
  color: white !important;
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.btn--artist:active {
  transform: translateY(0) scale(0.98);
}

/* ======================================
   PARTNERS SECTION (B2B)
   ====================================== */
.partners {
  padding: var(--space-2) 0 var(--space-4) 0;
  /* Reduced bottom padding to position the activities block higher */
  background: var(--color-bg);
  position: relative;
  overflow: hidden;
}

@media (min-width: 1024px) {
  .partners {
    padding: var(--space-3) 0 var(--space-6) 0;
    /* Reduced bottom padding to position the activities block higher */
  }
}

/* Card Container */
.partners__card {
  border: 1px solid var(--color-green-deep);
  border-radius: var(--radius-3xl);
  box-shadow: var(--shadow-md);
  padding: var(--space-5);
  position: relative;
  margin-top: 0;
  /* Removed margin-top since there is no top border header now */
  transition: box-shadow var(--transition-base);
}

.partners__card:hover {
  box-shadow: var(--shadow-lg);
}

@media (min-width: 768px) {
  .partners__card {
    padding: var(--space-8);
    padding-left: calc(220px + var(--space-8));
  }
}

@media (min-width: 1024px) {
  .partners__card {
    padding: var(--space-10);
    padding-left: calc(220px + var(--space-10));
  }
}

/* Responsive Grid */
.partners__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
  /* Reduced from space-8 (32px to 16px) for closer layout on mobile */
  align-items: center;
  position: relative;
  z-index: 2;
}

@media (min-width: 768px) {
  .partners__grid {
    grid-template-columns: 1.1fr 1.9fr;
    gap: var(--space-8);
  }
}

@media (min-width: 1024px) {
  .partners__grid {
    grid-template-columns: 1.35fr 1.85fr;
    gap: var(--space-1);
  }
}

/* Left Column: Handshake Illustration spanning entire height as an absolute aligned background */
.partners__visual {
  margin: -var(--space-5) -var(--space-5) var(--space-5) -var(--space-5);
  border-top-left-radius: var(--radius-3xl);
  border-top-right-radius: var(--radius-3xl);
  overflow: hidden;
  display: block;
  height: 170px;
  position: relative;
  z-index: 1;
}

.partners__handshake {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s var(--ease-out);
}

.partners__card:hover .partners__handshake {
  transform: scale(1.03);
}

@media (min-width: 768px) {
  .partners__visual {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    width: 50%;
    margin: 0;
    border-top-left-radius: var(--radius-3xl);
    border-bottom-left-radius: var(--radius-3xl);
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    overflow: hidden;
    display: block;
    height: 100%;
    z-index: 1;
  }

  .partners__handshake {
    height: 100%;
    width: auto;
    object-fit: contain;
    object-position: left center;
  }
}

@media (min-width: 1024px) {
  .partners__visual {
    width: 50%;
  }
}

/* Center Column: Text Content */
.partners__info {
  display: flex;
  flex-direction: column;
  gap: 6px;
  /* Reduced from 12px (space-3) to 6px for tighter spacing */
  text-align: left;
}

.partners__title {
  font-family: var(--font-serif);
  font-size: 1.625rem;
  font-weight: 700;
  line-height: 1.25;
  color: var(--color-green-deep);
}

@media (min-width: 1024px) {
  .partners__title {
    font-size: 1.5rem;
  }
}

.partners__text {
  margin-top: 4px;
  /* Отдельный отступ сверху для текста */
  font-size: 0.9375rem;
  color: var(--color-stone-600);
  line-height: 1.45;
  /* Reduced line-height from 1.65 to 1.45 for tighter text rows */
}

/* Right Column: List and CTA placed side-by-side on desktop */
.partners__action-block {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  position: relative;
  text-align: left;
}

@media (min-width: 1024px) {
  .partners__action-block {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-8);
    padding-left: var(--space-6);
    border-left: 1px dashed var(--color-green-mist);
    height: 100%;
  }

  .partners__friends {
    flex: 1;
    max-width: 65%;
  }

  .partners__cta {
    flex-shrink: 0;
    width: 220px;
  }
}

/* Friends List */
.partners__friends {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-top: -5px;
  /* Shifts the list up to the level of "Корпоративные участники" */
}

.partners__list-title {
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--color-stone-700);
  letter-spacing: 0.05em;
  margin-bottom: var(--space-2);
}

.partners__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  padding-left: 0;
  list-style: none;
}

.partners__item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  transition: transform var(--transition-base);
}

.partners__item:hover {
  transform: translateX(4px);
}

.partners__item-icon {
  color: var(--color-green-deep);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.35rem;
  width: 1.5rem;
  /* Ensures consistent alignment width matching the program list */
  flex-shrink: 0;
}

.partners__item-name {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-green-deep);
}

/* Partner CTA Button */
.btn--partner {
  border: 1px solid var(--color-green-deep);
  color: var(--color-green-deep);
  background: transparent;
  width: 100%;
  padding: 0.875rem var(--space-6);
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-sm);
  transition: all var(--transition-base);
  text-align: center;
}

.btn--partner:hover {
  background: var(--color-green-deep);
  color: white !important;
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.btn--partner:active {
  transform: translateY(0) scale(0.98);
}

/* ======================================
   ACTIVITIES SECTION (WHAT AWAITS YOU)
   ====================================== */
.activities {
  padding: var(--space-2) 0;
  background: var(--color-bg);
  position: relative;
  overflow: hidden;
}

@media (min-width: 1024px) {
  .activities {
    padding: var(--space-4) 0;
  }
}

.activities__card {
  position: relative;
  border-radius: var(--radius-3xl);
  border: 1px solid var(--color-green-mist);
  box-shadow: var(--shadow-md);
  padding: var(--space-4) var(--space-6);
  /* Extremely compact padding */
  text-align: center;
  overflow: hidden;
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

/* Elegant breathing background animation */
.activities__card::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url('/assets/tmpl/actions/891/img/fonfun.png');
  background-size: 100% 100%;
  background-position: center;
  background-repeat: no-repeat;
  z-index: 1;
  pointer-events: none;
  animation: activitiesBgBreath 24s infinite ease-in-out;
}

/* Interactive Spotlight Effect */
.activities__card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle 280px at var(--mouse-x, -999px) var(--mouse-y, -999px), rgba(88, 114, 77, 0.09), transparent 80%);
  z-index: 2;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.4s var(--ease-out);
}

.activities__card:hover::after {
  opacity: 1;
}

@keyframes activitiesBgBreath {

  0%,
  100% {
    transform: scale(1) translate(0, 0);
  }

  50% {
    transform: scale(1.04) translate(4px, 2px);
  }
}

.activities__card:hover {
  box-shadow: var(--shadow-lg);
}

.activities__header {
  position: relative;
  z-index: 3;
  max-width: 44rem;
  margin: 0 auto var(--space-3) auto;
  /* Reduced gap below header */
}

.activities__title {
  font-family: var(--font-serif);
  font-size: 1.625rem;
  font-weight: 700;
  color: var(--color-green);
  margin-bottom: var(--space-1);
  line-height: 1.25;
}

@media (min-width: 768px) {
  .activities__title {
    font-size: 1.875rem;
  }
}

.activities__subtitle {
  margin-top: 6px;
  /* Отдельный отступ сверху для текста */
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: var(--color-stone-700);
  line-height: 1.5;
  font-weight: 500;
}

.activities__grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4) var(--space-4);
  max-width: 100%;
  margin: 0 auto;
}

@media (min-width: 640px) {
  .activities__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4) var(--space-6);
  }
}

@media (min-width: 1024px) {
  .activities__grid {
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-4);
    max-width: 55rem;
    /* Clusters items closer to the center, leaving space on the sides */
  }
}

.activities__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  transition: transform var(--transition-base);
  padding: 0 var(--space-2);
}

.activities__item:hover {
  transform: translateY(-4px);
}

.activities__icon-wrap {
  width: 3.75rem;
  /* Smaller icon container */
  height: 3.75rem;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: -30px;
  /* Pulls titles much closer to icons */
  transition: transform 0.5s var(--ease-out);
}

.activities__item:hover .activities__icon-wrap {
  transform: scale(1.1);
}

.activities__icon-svg {
  width: 100%;
  height: 100%;
  color: var(--color-green);
  transition: color var(--transition-base);
}

.activities__item:hover .activities__icon-svg {
  color: var(--color-green-dark);
}

.activities__item-title {
  font-family: var(--font-sans);
  font-size: 0.95rem;
  /* Sleeker title */
  font-weight: 700;
  color: var(--color-green);
  margin-bottom: -14px;
  line-height: 1.3;
}

.activities__item-desc {
  font-family: var(--font-sans);
  font-size: 0.78rem;
  color: var(--color-stone-600);
  line-height: 1.4;
  max-width: 15rem;
}

.btn--outline-dark {
  border: 2px solid var(--color-green);
  color: var(--color-green);
  background: rgba(255, 255, 255, 0.75);
  padding: 0.625rem 1.5rem;
  font-size: 0.875rem;
  font-weight: 700;
  border-radius: var(--radius-full);
  transition: all var(--transition-base);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  cursor: pointer;
  z-index: 3;
  position: relative;
}

.btn--outline-dark:hover {
  background: var(--color-green);
  color: white !important;
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.btn--outline-dark:active {
  transform: translateY(0) scale(0.98);
}

/* ======================================
   CONCEPT SECTION (891 HEARTS)
   ====================================== */
.concept {
  /* ==========================================================================
     РУЧНАЯ НАСТРОЙКА СДВИГА КОНТЕНТА (ВЛЕВО / ВПРАВО) НА КОМПЬЮТЕРАХ
     Вы можете менять это значение прямо здесь, чтобы подвигать блок:
     0%  — контент прижат к левому краю (исходное положение)
     6%  — сдвинут чуть правее (рекомендуется для fonheart2.png)
     12% — сдвинут еще дальше вправо к центру
     ========================================================================== */
  --concept-desktop-shift: 2%;

  position: relative;
  padding: var(--space-4) 0 !important;
  background-image: url('/assets/tmpl/actions/891/img/fonheart2.png');
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  overflow: hidden;
  display: flex;
  align-items: center;
}

@media (min-width: 1024px) {
  .concept {
    padding: var(--space-6) 0 !important;
  }
}

/* Grid layout */
.concept__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-3) !important;
  align-items: center;
  position: relative;
  z-index: 3;
}

@media (min-width: 1024px) {
  .concept__grid {
    grid-template-columns: 1.35fr 0.65fr 1fr;
    gap: var(--space-2) !important;
    padding-left: var(--concept-desktop-shift) !important;
  }
}

/* Info Column */
.concept__info {
  display: flex;
  flex-direction: column;
  text-align: left;
  margin: 0 !important;
  padding: 0 !important;
}

/* For mobile/tablet under 1024px, we apply a gorgeous semi-transparent background to ensure readability */
@media (max-width: 1023px) {
  .concept__info {
    background: rgba(255, 255, 255, 0.9) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    padding: var(--space-4) var(--space-4) !important;
    border-radius: var(--radius-2xl) !important;
    border: 1px solid var(--color-green-mist) !important;
    box-shadow: var(--shadow-md) !important;
  }
}

.concept__title {
  font-family: var(--font-serif) !important;
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  color: var(--color-green) !important;
  line-height: 1.2 !important;
  margin: 0 0 var(--space-1) 0 !important;
}

@media (min-width: 768px) {
  .concept__title {
    font-size: 1.85rem !important;
  }
}

.concept__desc {
  font-family: var(--font-sans) !important;
  font-size: 0.85rem !important;
  color: var(--color-stone-600) !important;
  line-height: 1.45 !important;
  margin: 0 0 var(--space-2) 0 !important;
}

.concept__desc strong {
  color: var(--color-green) !important;
  font-weight: 700;
}

/* Custom Text Divider */
.concept__divider {
  display: flex !important;
  align-items: center !important;
  gap: var(--space-2) !important;
  margin: 0 0 var(--space-2) 0 !important;
  width: 100% !important;
}

.concept__divider-line {
  height: 1px;
  background: var(--color-green-pale);
  flex: 1;
  opacity: 0.6;
}

.concept__divider-text {
  font-family: var(--font-serif) !important;
  font-size: 0.9rem !important;
  font-weight: 700 !important;
  color: var(--color-green) !important;
  white-space: nowrap;
}

/* List details */
.concept__list {
  display: flex !important;
  flex-direction: column !important;
  gap: var(--space-2) !important;
  padding: 0 !important;
  margin: 0 0 var(--space-2) 0 !important;
  list-style: none !important;
}

.concept__item {
  display: flex !important;
  align-items: flex-start !important;
  gap: var(--space-3) !important;
  margin: 0 !important;
  padding: 0 !important;
  transition: transform var(--transition-base);
}

.concept__item:hover {
  transform: translateX(4px);
}

.concept__item-icon-wrap {
  width: 2rem !important;
  height: 2rem !important;
  border-radius: 50% !important;
  background: var(--color-green-wash) !important;
  border: 1px solid var(--color-green-mist) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  transition: background var(--transition-base), transform var(--transition-base);
}

.concept__item:hover .concept__item-icon-wrap {
  background: var(--color-green-mist) !important;
  transform: scale(1.06) !important;
}

.concept__item-icon {
  font-size: 1.05rem !important;
  color: var(--color-green) !important;
}

.concept__item-content {
  display: flex !important;
  flex-direction: column !important;
  text-align: left !important;
  margin: 0 !important;
  padding: 0 !important;
}

.concept__item-title {
  font-family: var(--font-sans) !important;
  font-size: 0.85rem !important;
  font-weight: 700 !important;
  color: var(--color-green) !important;
  margin: 0 0 1px 0 !important;
}

.concept__item-desc {
  font-family: var(--font-sans) !important;
  font-size: 0.78rem !important;
  color: var(--color-stone-600) !important;
  line-height: 1.35 !important;
  margin: 0 !important;
}

/* Dashed horizontal divider */
.concept__dashed-line {
  border: none !important;
  border-top: 1px dashed var(--color-green-pale) !important;
  margin: 0 0 var(--space-2) 0 !important;
  opacity: 0.6;
}

/* Slogan highlight */
.concept__slogan {
  font-family: var(--font-sans) !important;
  font-size: 0.85rem !important;
  font-weight: 700 !important;
  color: var(--color-green) !important;
  line-height: 1.35 !important;
  margin: 0 0 var(--space-2) 0 !important;
  text-align: left !important;
}

/* CTA concept button */
.concept__cta {
  display: flex !important;
  justify-content: flex-start !important;
  margin: 0 !important;
}

.btn--cta-concept {
  background: var(--color-green) !important;
  color: white !important;
  padding: 0.45rem var(--space-6) !important;
  font-size: 0.825rem !important;
  font-weight: 700 !important;
  border-radius: var(--radius-full) !important;
  box-shadow: var(--shadow-sm) !important;
  transition: all var(--transition-base);
}

.btn--cta-concept:hover {
  background: var(--color-green-dark) !important;
  color: white !important;
  box-shadow: var(--shadow-md) !important;
  transform: translateY(-2px);
}

.btn--cta-concept:active {
  transform: translateY(0) scale(0.98);
}

/* Center space for visual */
.concept__middle-space {
  display: none;
}

@media (min-width: 1024px) {
  .concept__middle-space {
    display: block;
    height: 100%;
    min-height: 150px;
  }
}

/* ======================================
   CONCEPT MOUSE PULSE & TRACKER
   ====================================== */
.concept-cursor-dot {
  position: absolute;
  width: 10px;
  height: 10px;
  background: var(--color-green);
  border-radius: 50%;
  pointer-events: none;
  z-index: 10;
  transform: translate(-50%, -50%) scale(0);
  transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275), opacity 0.3s ease;
  box-shadow: 0 0 10px var(--color-green), 0 0 20px rgba(74, 112, 70, 0.5);
  opacity: 0;
}

.concept-cursor-dot.active {
  transform: translate(-50%, -50%) scale(1);
  opacity: 0.9;
}

.concept-ecg-wave {
  position: absolute;
  width: 90px;
  height: 30px;
  pointer-events: none;
  z-index: 9;
  transform: translate(0, -50%);
  color: var(--color-green);
  opacity: 0;
  filter: drop-shadow(0 0 3px rgba(74, 112, 70, 0.6));
  animation: conceptEcgRun 1.8s cubic-bezier(0.15, 0.85, 0.35, 1) forwards;
}

.concept-ecg-wave--click {
  color: var(--color-green-dark);
  filter: drop-shadow(0 0 5px rgba(50, 80, 48, 0.8));
  animation-duration: 2.1s;
  width: 120px;
  height: 40px;
}

.concept-ecg-path {
  stroke-dasharray: 180;
  stroke-dashoffset: 180;
  animation: conceptEcgDraw 1.4s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}

.concept-ecg-wave--click .concept-ecg-path {
  stroke-dasharray: 250;
  stroke-dashoffset: 250;
  animation-duration: 1.6s;
}

@keyframes conceptEcgDraw {
  0% {
    stroke-dashoffset: 180;
  }

  100% {
    stroke-dashoffset: 0;
  }
}

@keyframes conceptEcgRun {
  0% {
    opacity: 0;
    transform: translate(-10px, -50%);
  }

  20% {
    opacity: 1;
  }

  75% {
    opacity: 0.8;
  }

  100% {
    opacity: 0;
    transform: translate(130px, -50%);
  }
}

/* ECG starting circle ripple effect */
.concept-ecg-ripple {
  position: absolute;
  width: 14px;
  height: 14px;
  border: 1px solid var(--color-green);
  border-radius: 50%;
  pointer-events: none;
  z-index: 8;
  transform: translate(-50%, -50%) scale(0.1);
  opacity: 0.8;
  animation: conceptEcgRippleRun 0.8s cubic-bezier(0.1, 0.8, 0.3, 1) forwards;
}

.concept-ecg-ripple--click {
  border-color: var(--color-green-dark);
  border-width: 1.5px;
  animation-duration: 1.1s;
}

@keyframes conceptEcgRippleRun {
  0% {
    transform: translate(-50%, -50%) scale(0.1);
    opacity: 0.8;
    box-shadow: 0 0 4px rgba(74, 112, 70, 0.3);
  }

  100% {
    transform: translate(-50%, -50%) scale(3.5);
    opacity: 0;
    box-shadow: 0 0 0px rgba(74, 112, 70, 0);
  }
}

/* ======================================
   MOBILE & TABLET FIXES (added by Claude)
   Fix shifted images, text overflow, and
   broken layouts on small/medium screens.
   ====================================== */

/* Prevent horizontal scroll across the whole page */
html, body {
  overflow-x: hidden;
  max-width: 100vw;
}

/* Section heading backdrop "891" — prevent horizontal overflow on small screens */
.section-heading--backdrop {
  overflow: hidden;
}

@media (max-width: 480px) {
  .section-heading--backdrop .section-heading__backdrop {
    font-size: 5rem;
    white-space: nowrap;
  }
}

/* === HERO === */
/* On phones, make image frame less tall (mobile photo ratio) */
@media (max-width: 1023px) {
  .hero__image-frame {
    aspect-ratio: 16 / 11;
  }

  .hero__image-fg {
    width: 65%;
    max-width: 320px;
  }

  .hero__visual {
    padding: 0 var(--space-4);
  }
}

@media (max-width: 480px) {
  .hero__image-frame {
    aspect-ratio: 4 / 3;
    border-radius: 1.25rem;
    border-width: 3px;
  }

  .hero__image-fg {
    width: 72%;
    height: 78%;
  }
}

/* === CAMPAIGN top row stacks cleanly on small screens === */
@media (max-width: 767px) {
  .campaign__top-row {
    gap: var(--space-3);
  }

  .campaign__stat-col,
  .campaign__center-col {
    text-align: center;
    align-items: center;
  }

  .campaign__stat-value {
    justify-content: center;
  }
}

/* === VALUES (Хоспис «Анастасия» — это…) === */
/* Tablet: was jumping from 1 col straight to 2 cols at 768px;
   value-card titles are long, so prevent overflow */
@media (max-width: 767px) {
  .value-card {
    padding: var(--space-3) var(--space-2);
  }

  .value-card__title {
    font-size: 0.95rem;
    line-height: 1.35;
  }
}

/* Tab panels: stack columns on tablets cleanly */
@media (max-width: 1023px) {
  .tab-panel-card__grid {
    grid-template-columns: 1fr !important;
    gap: var(--space-5);
  }

  .tab-panel-card__photos {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 480px) {
  .tab-panel-card__photos {
    grid-template-columns: 1fr;
  }
}

/* Stats grid: avoid tiny boxes on phones */
@media (max-width: 479px) {
  .stats-grid {
    grid-template-columns: 1fr 1fr;
  }

  .stat-card__number {
    font-size: 1.5rem;
  }

  .stat-card__label {
    font-size: 0.75rem;
  }
}

/* === HOW TO HELP cards === */
@media (max-width: 767px) {
  .help-card {
    padding: var(--space-5) var(--space-4);
  }

  .help-card__icon-badge {
    transform: translate(-50%, -45%);
  }

  .share-buttons__list {
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-2);
  }

  .share-btn-pill {
    flex: 1 1 auto;
    min-width: 110px;
    justify-content: center;
  }
}

/* === PROGRAM section: gazebo image alignment === */
@media (max-width: 767px) {
  .program__visual {
    margin: calc(var(--space-5) * -1) calc(var(--space-5) * -1) var(--space-4) calc(var(--space-5) * -1);
    height: 180px;
  }

  .program__gazebo {
    object-fit: cover;
    object-position: center;
  }

  .section-heading--program {
    transform: translate(-50%, -50%);
    max-width: calc(100% - var(--space-8));
  }

  .section-heading--program .section-heading__title {
    font-size: 1.15rem;
    white-space: normal;
    text-align: center;
  }

  .section-heading--program .section-heading__title-wrap {
    flex-wrap: nowrap;
    gap: 0;
  }

  .program-heading-decor {
    --decor-size: 38px;
  }

  .program__title {
    font-size: 1.35rem;
  }

  .program__participants {
    width: 100%;
  }
}

/* Tablet: avoid double padding-left from program__card 220px shift */
@media (min-width: 768px) and (max-width: 991px) {
  .program__card {
    padding-left: calc(180px + var(--space-6));
    padding-right: var(--space-6);
    padding-top: var(--space-6);
    padding-bottom: var(--space-6);
  }

  .program__visual {
    width: 45%;
  }

  .program__title {
    font-size: 1.35rem;
  }
}

/* === PARTNERS section: handshake image alignment === */
@media (max-width: 767px) {
  .partners__visual {
    margin: calc(var(--space-5) * -1) calc(var(--space-5) * -1) var(--space-4) calc(var(--space-5) * -1);
    height: 180px;
  }

  .partners__handshake {
    object-fit: cover;
    object-position: center;
  }

  .partners__title {
    font-size: 1.35rem;
  }
}

@media (min-width: 768px) and (max-width: 991px) {
  .partners__card {
    padding-left: calc(180px + var(--space-6));
    padding-right: var(--space-6);
    padding-top: var(--space-6);
    padding-bottom: var(--space-6);
  }

  .partners__visual {
    width: 45%;
  }
}

/* === ACTIVITIES (стенд хосписа) === */
@media (max-width: 767px) {
  .activities__card {
    padding: var(--space-4) var(--space-3);
  }

  .activities__grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-3);
  }

  .activities__icon-wrap {
    margin-bottom: -18px;
  }

  .activities__icon-wrap img {
    max-width: 80px;
    height: auto;
  }

  .activities__item-title {
    font-size: 0.95rem;
  }

  .activities__item-desc {
    font-size: 0.78rem;
  }
}

@media (max-width: 380px) {
  .activities__grid {
    grid-template-columns: 1fr;
  }
}

/* === CONCEPT (891 doброе сердце — что это?) === */
@media (max-width: 1023px) {
  .concept__grid {
    grid-template-columns: 1fr;
  }

  .concept__middle-space {
    display: none;
  }

  .concept__title {
    font-size: 1.75rem;
  }

  .concept__item-title {
    font-size: 1rem;
  }

  .concept__item-desc {
    font-size: 0.9rem;
  }
}

@media (max-width: 480px) {
  .concept__title {
    font-size: 1.5rem;
    line-height: 1.2;
  }

  .concept__item {
    gap: var(--space-3);
  }
}

/* === FOOTER === */
/* Mobile: cancel the desktop left-shift to fit content cleanly */
@media (max-width: 767px) {
  .site-footer {
    --footer-compact-left-shift: var(--space-4);
    background-size: auto 200px;
    background-position: center top -20px;
  }

  .footer__bottom-info {
    padding-left: var(--space-4) !important;
    padding-right: var(--space-4) !important;
    font-size: 0.7rem;
  }
}

@media (max-width: 480px) {
  .footer__brand-name {
    font-size: 1.1rem;
  }

  .footer__phone {
    font-size: 1rem;
  }

  .footer__email {
    font-size: 0.75rem;
    word-break: break-all;
  }

  .footer__support-btn {
    padding: 0.65rem 1.5rem;
    font-size: 0.85rem;
  }
}

/* === MODALS === */
@media (max-width: 600px) {
  .uk-modal-dialog {
    margin: 1rem !important;
  }

  .uk-modal-body {
    padding: var(--space-4) !important;
  }

  .form-row {
    grid-template-columns: 1fr !important;
    gap: var(--space-3) !important;
  }
}

/* === GENERIC: prevent images from breaking layouts === */
img {
  max-width: 100%;
}

/* Hero blobs should not cause horizontal scroll on mobile */
.hero__blur-blobs,
.hero__blob {
  pointer-events: none;
}
