:root {
      --ink: #172331;
      --muted: #607184;
      --blue: #0b78b6;
      --blue-dark: #075b8e;
      --blue-soft: #e9f6ff;
      --green: #1d8a6b;
      --orange: #f28a2e;
      --paper: #ffffff;
      --wash: #f7fbff;
      --line: #d9e8f2;
      --shadow: 0 18px 50px rgba(26, 69, 98, 0.12);
      --radius: 8px;
      --max: 1180px;
    }

    * {
      box-sizing: border-box;
    }

    html {
      scroll-behavior: smooth;
    }

    body {
      margin: 0;
      font-family: Inter, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
      color: var(--ink);
      background: var(--wash);
      line-height: 1.65;
    }

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

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

    .container {
      width: min(calc(100% - 36px), var(--max));
      margin: 0 auto;
    }

    .site-header {
      position: sticky;
      top: 0;
      z-index: 50;
      border-bottom: 1px solid rgba(217, 232, 242, 0.85);
      background: rgba(255, 255, 255, 0.92);
      backdrop-filter: blur(18px);
    }

    .nav {
      min-height: 82px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 24px;
    }

    .brand {
      display: inline-flex;
      align-items: center;
      gap: 12px;
      font-weight: 800;
      letter-spacing: 0;
    }

    .brand img {
      width: 58px;
      height: 58px;
      object-fit: contain;
      border-radius: 50%;
      background: white;
      box-shadow: 0 8px 22px rgba(11, 120, 182, 0.14);
    }

    .brand span {
      display: block;
      line-height: 1.15;
    }

    .brand small {
      display: block;
      margin-top: 2px;
      color: var(--muted);
      font-size: 0.78rem;
      font-weight: 650;
    }

    .menu {
      display: flex;
      align-items: center;
      gap: 2px;
      margin: 0;
      padding: 0;
      list-style: none;
      font-size: 0.92rem;
      font-weight: 750;
      color: #304255;
    }

    .menu a {
      display: inline-flex;
      min-height: 42px;
      align-items: center;
      border-radius: 999px;
      padding: 0 13px;
    }

.menu a:hover,
.menu a:focus-visible {
  background: var(--blue-soft);
  color: var(--blue-dark);
  outline: none;
}

.language-switcher {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 4px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: #fff;
}

.language-switcher a {
  display: inline-flex;
  min-width: 42px;
  min-height: 36px;
  align-items: center;
  justify-content: center;
  gap: 4px;
  border-radius: 999px;
  color: #304255;
  font-size: 0.82rem;
  font-weight: 850;
}

.language-switcher a:hover,
.language-switcher a:focus-visible,
.language-switcher a.is-active {
  background: var(--blue-soft);
  color: var(--blue-dark);
  outline: none;
}

.language-switcher span {
  font-size: 0.68rem;
}

.phone-link a {
  width: 42px;
  padding: 0;
  justify-content: center;
  color: var(--blue-dark);
  border: 1px solid var(--line);
  background: #fff;
}

.phone-link svg {
  width: 19px;
  height: 19px;
  stroke: currentColor;
  stroke-width: 2.2;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

    .button {
      display: inline-flex;
      min-height: 46px;
      align-items: center;
      justify-content: center;
      gap: 9px;
      border: 0;
      border-radius: 999px;
      padding: 0 22px;
      background: var(--blue);
      color: #fff;
      font: inherit;
      font-size: 0.94rem;
      font-weight: 800;
      cursor: pointer;
      box-shadow: 0 12px 24px rgba(11, 120, 182, 0.22);
      transition: transform 180ms ease, box-shadow 180ms ease, background 180ms ease;
    }

    .button:hover,
    .button:focus-visible {
      transform: translateY(-1px);
      background: var(--blue-dark);
      box-shadow: 0 16px 30px rgba(11, 120, 182, 0.28);
      outline: none;
    }

    .button.secondary {
      background: #fff;
      color: var(--blue-dark);
      border: 1px solid var(--line);
      box-shadow: none;
    }

    .button.orange {
      background: var(--orange);
      box-shadow: 0 12px 24px rgba(242, 138, 46, 0.22);
    }

    .hero {
      position: relative;
      overflow: hidden;
      background: linear-gradient(180deg, #ffffff 0%, #eef8ff 100%);
    }

    .hero::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        linear-gradient(90deg, rgba(255, 255, 255, 0.98) 0%, rgba(255, 255, 255, 0.78) 42%, rgba(255, 255, 255, 0.1) 100%),
        url("assets/images/89fdaa_92919d422d144fb19586f32d98f280e1mv2.jpg") center right / cover no-repeat;
      opacity: 0.95;
    }

    .hero-grid {
      position: relative;
      min-height: 680px;
      display: grid;
      grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.75fr);
      align-items: center;
      gap: 56px;
      padding: 82px 0 72px;
    }

    .hero h1 {
      max-width: 820px;
      margin: 0;
      font-size: clamp(2.7rem, 7vw, 6.2rem);
      line-height: 0.95;
      letter-spacing: 0;
    }

    .hero p {
      max-width: 660px;
      margin: 26px 0 0;
      color: #31465a;
      font-size: clamp(1.05rem, 1.4vw, 1.28rem);
    }

    .hero-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
      margin-top: 34px;
    }

    .hero-card {
      align-self: end;
      margin-bottom: 8px;
      border: 1px solid rgba(217, 232, 242, 0.9);
      border-radius: var(--radius);
      background: rgba(255, 255, 255, 0.9);
      box-shadow: var(--shadow);
      padding: 28px;
    }

    .hero-card strong {
      display: block;
      color: var(--blue-dark);
      font-size: 2.2rem;
      line-height: 1;
    }

    .hero-card span {
      display: block;
      margin-top: 7px;
      color: var(--muted);
      font-weight: 700;
    }

    .stats {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      border-top: 1px solid var(--line);
      border-bottom: 1px solid var(--line);
      background: var(--paper);
    }

    .stat {
      min-height: 126px;
      padding: 28px 24px;
      border-right: 1px solid var(--line);
    }

    .stat:last-child {
      border-right: 0;
    }

    .stat strong {
      display: block;
      color: var(--blue-dark);
      font-size: clamp(2rem, 4vw, 3.4rem);
      line-height: 1;
    }

    .stat span {
      display: block;
      margin-top: 8px;
      color: var(--muted);
      font-size: 0.95rem;
      font-weight: 750;
    }

    section {
      padding: 92px 0;
    }

    .section-title {
      max-width: 780px;
      margin-bottom: 36px;
    }

    .section-title h2 {
      margin: 0;
      font-size: clamp(2rem, 4vw, 3.7rem);
      line-height: 1.04;
      letter-spacing: 0;
    }

    .section-title p {
      margin: 16px 0 0;
      color: var(--muted);
      font-size: 1.08rem;
    }

    .split {
      display: grid;
      grid-template-columns: minmax(0, 0.95fr) minmax(320px, 1fr);
      gap: 58px;
      align-items: center;
    }

    .copy p {
      color: #34495d;
      font-size: 1.07rem;
    }

    .copy .lead {
      color: var(--ink);
      font-size: 1.35rem;
      line-height: 1.45;
      font-weight: 780;
    }

    .photo-stack {
      display: grid;
      grid-template-columns: 0.9fr 1fr;
      gap: 14px;
      align-items: end;
    }

    .photo-stack img {
      width: 100%;
      aspect-ratio: 4 / 5;
      object-fit: cover;
      border-radius: var(--radius);
      box-shadow: var(--shadow);
    }

    .photo-stack img:nth-child(2) {
      aspect-ratio: 1 / 1;
      transform: translateY(-32px);
    }

    .soft-band {
      background: #fff;
      border-top: 1px solid var(--line);
      border-bottom: 1px solid var(--line);
    }

    .help-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 18px;
    }

    .help-card,
    .press-card,
    .review,
    .contact-panel {
      border: 1px solid var(--line);
      border-radius: var(--radius);
      background: var(--paper);
      box-shadow: 0 12px 34px rgba(27, 65, 91, 0.08);
    }

    .help-card {
      padding: 30px;
    }

    .help-card .icon {
      display: inline-grid;
      width: 48px;
      height: 48px;
      place-items: center;
      border-radius: 50%;
      margin-bottom: 24px;
      color: white;
      background: var(--green);
    }

    .help-card:nth-child(2) .icon {
      background: var(--orange);
    }

    .help-card:nth-child(3) .icon {
      background: var(--blue);
    }

    .help-card h3 {
      margin: 0 0 10px;
      font-size: 1.25rem;
    }

    .help-card p {
      margin: 0;
      color: var(--muted);
    }

    .donation {
      background: linear-gradient(135deg, #0b78b6 0%, #1d8a6b 100%);
      color: #fff;
    }

    .donation .section-title p {
      color: rgba(255, 255, 255, 0.82);
    }

.donation-grid {
  display: grid;
  grid-template-columns: minmax(300px, 0.9fr) minmax(0, 1.1fr);
  gap: 28px;
  align-items: start;
}

.contact-form-section {
  background: #fff;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.contact-form-grid {
  display: grid;
  grid-template-columns: minmax(280px, 0.72fr) minmax(0, 1.28fr);
  gap: 28px;
  align-items: start;
}

.bank-box,
.material-form,
.contact-form-card,
.contact-info-card {
  border-radius: var(--radius);
  background: #fff;
  color: var(--ink);
  box-shadow: 0 16px 44px rgba(27, 65, 91, 0.1);
}

.bank-box,
.contact-form-card,
.contact-info-card {
  padding: 32px;
}

.bank-box h3,
.material-form h3,
.contact-form-card h3,
.contact-info-card h3 {
  margin: 0 0 14px;
  font-size: 1.55rem;
}

.contact-form-card,
.contact-info-card {
  border: 1px solid var(--line);
}

.contact-info-card p {
  color: var(--muted);
}

    .iban {
      margin: 18px 0 0;
      padding: 18px;
      border: 1px solid var(--line);
      border-radius: var(--radius);
      background: #f6fbff;
      color: var(--blue-dark);
      font-size: 1.18rem;
      font-weight: 850;
      overflow-wrap: anywhere;
    }

.material-form {
  display: block;
  padding: 32px;
}

    form {
      display: grid;
      gap: 16px;
    }

    .form-row {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 14px;
    }

    label {
      display: grid;
      gap: 7px;
      color: #31465a;
      font-size: 0.92rem;
      font-weight: 760;
    }

    input,
    textarea {
      width: 100%;
      min-height: 48px;
      border: 1px solid #cbdce8;
      border-radius: var(--radius);
      padding: 12px 14px;
      color: var(--ink);
      background: #fff;
      font: inherit;
      font-size: 1rem;
    }

    textarea {
      min-height: 110px;
      resize: vertical;
    }

    input:focus,
    textarea:focus {
      border-color: var(--blue);
      outline: 3px solid rgba(11, 120, 182, 0.14);
    }

    .check-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 10px;
    }

    .check {
      display: flex;
      align-items: flex-start;
      gap: 10px;
      min-height: 62px;
      border: 1px solid #cbdce8;
      border-radius: var(--radius);
      padding: 12px;
      background: #f8fcff;
      color: #31465a;
      cursor: pointer;
    }

    .check input {
      width: 18px;
      height: 18px;
      min-height: auto;
      margin-top: 3px;
      accent-color: var(--blue);
    }

.recaptcha-note {
  margin: 0;
  color: var(--muted);
  font-size: 0.86rem;
}

.form-status {
  min-height: 1.4em;
  margin: 0;
  color: var(--blue-dark);
  font-size: 0.92rem;
  font-weight: 760;
}

    .gallery {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 12px;
    }

    .gallery img {
      width: 100%;
      aspect-ratio: 1 / 0.76;
      object-fit: cover;
      border-radius: var(--radius);
      background: #dfeef8;
    }

    .reviews {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 18px;
    }

    .review {
      padding: 26px;
    }

    .review blockquote {
      margin: 0;
      color: #2c4052;
      font-size: 1.05rem;
      font-style: italic;
    }

    .review cite {
      display: block;
      margin-top: 16px;
      color: var(--orange);
      font-style: normal;
      font-weight: 850;
    }

    .press-list {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 16px;
    }

    .press-card {
      display: grid;
      gap: 10px;
      padding: 24px;
    }

    .press-card time {
      color: var(--blue-dark);
      font-weight: 850;
    }

    .press-card span {
      color: var(--muted);
    }

    .media-links {
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
      margin-top: 24px;
    }

    .contact {
      background: #fff;
    }

    .contact-grid {
      display: grid;
      grid-template-columns: minmax(300px, 0.85fr) minmax(0, 1.15fr);
      gap: 28px;
      align-items: stretch;
    }

    .contact-panel {
      padding: 30px;
    }

    .contact-panel p {
      margin: 0 0 14px;
      color: var(--muted);
    }

    .contact-list {
      display: grid;
      gap: 12px;
      margin-top: 24px;
    }

    .contact-list a,
    .contact-list span {
      display: flex;
      align-items: center;
      gap: 10px;
      min-height: 44px;
      color: #31465a;
      font-weight: 760;
    }

    .partners {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 18px;
      align-items: center;
      margin-top: 34px;
    }

    .partner {
      display: grid;
      min-height: 128px;
      place-items: center;
      border: 1px solid var(--line);
      border-radius: var(--radius);
      background: #fff;
      padding: 18px;
    }

    .partner img {
      max-height: 86px;
      object-fit: contain;
    }

    footer {
      padding: 44px 0;
      background: #172331;
      color: #d7e6ef;
    }

    .footer-grid {
      display: grid;
      grid-template-columns: 1.2fr repeat(3, 1fr);
      gap: 22px;
      align-items: start;
    }

    footer h2,
    footer h3,
    footer p {
      margin: 0;
    }

    footer h2 {
      color: #fff;
      font-size: 1.3rem;
    }

    footer h3 {
      color: #fff;
      font-size: 0.94rem;
      margin-bottom: 8px;
    }

    footer a {
      color: #fff;
      text-decoration: underline;
      text-decoration-thickness: 1px;
      text-underline-offset: 3px;
    }

    .mobile-cta {
      display: none;
    }

    @media (max-width: 980px) {
      .nav {
        min-height: auto;
        padding: 14px 0;
        align-items: flex-start;
      }

      .menu {
        display: none;
      }

      .language-switcher {
        margin-left: auto;
      }

      .mobile-cta {
        display: inline-flex;
      }

      .hero-grid,
      .split,
      .donation-grid,
      .contact-form-grid,
      .contact-grid {
        grid-template-columns: 1fr;
      }

      .hero-grid {
        min-height: auto;
        padding: 78px 0 52px;
      }

      .hero::before {
        background:
          linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(255, 255, 255, 0.86) 62%, rgba(255, 255, 255, 0.48) 100%),
          url("assets/images/89fdaa_92919d422d144fb19586f32d98f280e1mv2.jpg") center / cover no-repeat;
      }

      .hero-card {
        max-width: 420px;
      }

      .stats,
      .help-grid,
      .reviews,
      .press-list,
      .partners {
        grid-template-columns: repeat(2, 1fr);
      }

      .gallery {
        grid-template-columns: repeat(3, 1fr);
      }

      .footer-grid {
        grid-template-columns: 1fr 1fr;
      }
    }

    @media (max-width: 640px) {
      .container {
        width: min(calc(100% - 28px), var(--max));
      }

      section {
        padding: 68px 0;
      }

      .brand img {
        width: 48px;
        height: 48px;
      }

      .brand small {
        display: none;
      }

      .button {
        width: 100%;
      }

      .hero-actions {
        align-items: stretch;
      }

      .stats,
      .help-grid,
      .reviews,
      .press-list,
      .partners,
      .footer-grid,
      .form-row,
      .check-grid {
        grid-template-columns: 1fr;
      }

      .stat {
        border-right: 0;
        border-bottom: 1px solid var(--line);
      }

      .stat:last-child {
        border-bottom: 0;
      }

      .photo-stack,
      .gallery {
        grid-template-columns: 1fr 1fr;
      }

      .photo-stack img:nth-child(2) {
        transform: none;
      }

      .material-form,
      .bank-box,
      .contact-panel {
        padding: 22px;
      }
    }
  
