    :root {
      --ink: #22312b;
      --muted: #657066;
      --green: #7f8b66;
      --green-dark: #596847;
      --sage: #eef3e9;
      --mist: #faf7ef;
      --clay: #8f9b74;
      --blue: #6f8264;
      --white: #fffdf8;
      --line: rgba(34, 49, 43, 0.14);
      --shadow: 0 18px 45px rgba(29, 45, 37, 0.12);
    }

    * {
      box-sizing: border-box;
    }

    html {
      scroll-behavior: smooth;
      scroll-padding-top: 92px;
    }

    body {
      margin: 0;
      font-family: Arial, Helvetica, sans-serif;
      color: var(--ink);
      background: var(--mist);
      line-height: 1.65;
    }

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

    a {
      color: inherit;
    }

    .wrap {
      width: min(1120px, calc(100% - 40px));
      margin: 0 auto;
    }

    .site-header {
      position: fixed;
      inset: 0 0 auto;
      z-index: 20;
      background: rgba(255, 253, 248, 0.92);
      border-bottom: 1px solid var(--line);
      backdrop-filter: blur(14px);
      padding: 10px 0;
    }

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

    .brand {
      display: inline-flex;
      align-items: center;
      gap: 12px;
      text-decoration: none;
      min-width: max-content;
    }

    .brand-logo {
      width: 176px;
      height: auto;
      object-fit: contain;
      object-position: left center;
    }

    .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;
    }

    .nav {
      display: flex;
      align-items: center;
      justify-content: flex-end;
      gap: 16px;
      color: var(--green-dark);
      font-size: 13px;
      font-weight: 700;
    }

    .nav a {
      text-decoration: none;
      border-bottom: 2px solid transparent;
      padding: 8px 0;
    }

    .nav a:hover,
    .nav a:focus-visible {
      border-color: var(--clay);
      outline: none;
    }

    .header-actions {
      display: flex;
      align-items: center;
      gap: 10px;
    }

    button,
    .button {
      min-height: 44px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 9px;
      border: 0;
      border-radius: 8px;
      padding: 12px 17px;
      font: inherit;
      font-size: 14px;
      font-weight: 700;
      text-decoration: none;
      cursor: pointer;
      transition: transform 180ms ease, background 180ms ease, color 180ms ease, border-color 180ms ease;
    }

    button:hover,
    .button:hover {
      transform: translateY(-1px);
    }

    .lang-links {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      font-size: 13px;
      font-weight: 700;
      color: var(--green-dark);
    }

    .lang-links a {
      text-decoration: none;
      padding: 8px 6px;
      border-bottom: 2px solid transparent;
    }

    .lang-links a:hover,
    .lang-links a:focus-visible {
      border-color: var(--clay);
      outline: none;
    }

    html[lang="et"] .lang-links a[lang="et"],
    html[lang="ru"] .lang-links a[lang="ru"] {
      border-color: var(--green-dark);
    }

    .menu-toggle {
      display: none;
      width: 44px;
      padding: 0;
      color: var(--white);
      background: var(--green);
    }

    .menu-toggle svg,
    .button svg,
    .contact-line svg {
      width: 18px;
      height: 18px;
      flex: 0 0 auto;
    }

    .hero {
      min-height: calc(100svh - 26px);
      display: flex;
      align-items: center;
      padding: 116px 0 54px;
      color: var(--green-dark);
      background:
        linear-gradient(90deg, rgba(255, 253, 248, 0.96), rgba(255, 253, 248, 0.76) 42%, rgba(255, 253, 248, 0.24)),
        image-set(url("../images/hero.webp") type("image/webp"), url("../images/hero.jpg") type("image/jpeg")) bottom right / 70%;
      background-repeat: no-repeat;
      background-color: var(--white);
    }

    .hero-content {
      width: min(760px, 100%);
    }

    .eyebrow {
      margin: 0 0 16px;
      color: var(--green);
      font-size: clamp(24px, 2.4vw, 32px);
      font-weight: 700;
      letter-spacing: 0;
      text-transform: none;
    }

    .hero .eyebrow {
      color: var(--green);
      font-size: 13px;
      letter-spacing: 0.08em;
      text-transform: uppercase;
    }

    h1,
    h2,
    h3,
    p {
      margin-top: 0;
    }

    h1 {
      max-width: 760px;
      margin-bottom: 22px;
      font-size: clamp(42px, 7vw, 76px);
      font-weight: 700;
      line-height: 1.02;
      letter-spacing: 0;
    }

    .hero-text {
      max-width: 650px;
      margin-bottom: 30px;
      color: var(--muted);
      font-size: clamp(18px, 2vw, 21px);
    }

    .actions {
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
    }

    .button.primary {
      color: var(--white);
      background: var(--green-dark);
    }

    .button.secondary {
      color: var(--green-dark);
      border: 1px solid rgba(89, 104, 71, 0.35);
      background: rgba(255, 253, 248, 0.72);
    }

    .button.dark {
      color: var(--white);
      background: var(--green);
    }

    .intro-strip {
      background: var(--white);
      border-bottom: 1px solid var(--line);
    }

    .strip-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 1px;
      background: var(--line);
    }

    .strip-item {
      min-height: 118px;
      padding: 25px;
      background: var(--white);
    }

    .strip-item strong {
      display: block;
      color: var(--green-dark);
      font-size: 18px;
      line-height: 1.25;
    }

    .strip-item span {
      display: block;
      margin-top: 7px;
      color: var(--muted);
      font-size: 14px;
      line-height: 1.45;
    }

    section {
      padding: 86px 0;
      scroll-margin-top: 92px;
    }

    .section-head {
      max-width: 780px;
      margin-bottom: 34px;
    }

    h2 {
      margin-bottom: 16px;
      color: var(--green-dark);
      font-size: clamp(32px, 4vw, 48px);
      font-weight: 700;
      line-height: 1.08;
      letter-spacing: 0;
    }

    .lead {
      color: var(--muted);
      font-size: 18px;
    }

    .about-layout {
      display: grid;
      grid-template-columns: minmax(0, 1fr) 360px;
      gap: 42px;
      align-items: start;
    }

    .about-copy p {
      max-width: 760px;
      color: #3d4b45;
      font-size: 17px;
    }

    .note-panel {
      padding: 26px;
      border-radius: 8px;
      color: var(--white);
      background: var(--blue);
      box-shadow: var(--shadow);
    }

    .note-panel strong {
      display: block;
      margin-bottom: 9px;
      font-size: 20px;
      line-height: 1.25;
    }

    .soft {
      background: var(--sage);
    }

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

    .service {
      overflow: hidden;
      border-radius: 8px;
      background: var(--white);
      box-shadow: 0 14px 32px rgba(32, 52, 40, 0.09);
    }

    .service img {
      width: 100%;
      height: 218px;
      object-fit: cover;
    }

    .service-body {
      padding: 24px;
    }

    .service h3 {
      margin-bottom: 10px;
      color: var(--green-dark);
      font-size: 21px;
      line-height: 1.22;
    }

    .service p {
      margin-bottom: 0;
      color: var(--muted);
    }

    .service-cta {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 18px;
      margin-top: 24px;
      padding: 22px 24px;
      border-radius: 8px;
      color: var(--white);
      background: var(--green-dark);
    }

    .service-cta p {
      margin: 0;
      max-width: 680px;
    }

    .service-cta .button {
      min-width: max-content;
      color: var(--green-dark);
      background: var(--white);
    }

    .daily-layout {
      display: grid;
      grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
      gap: 34px;
      align-items: start;
    }

    .daily-copy {
      max-width: 760px;
    }

    .daily-copy h3,
    .story h3,
    .help-card h3,
    .step h3 {
      margin-bottom: 10px;
      color: var(--green-dark);
      font-size: 22px;
      line-height: 1.22;
    }

    .daily-copy p,
    .story p,
    .help-card p,
    .step p {
      color: #3d4b45;
    }

    .daily-photo {
      position: sticky;
      top: 104px;
      overflow: hidden;
      border-radius: 8px;
      background: var(--white);
      box-shadow: var(--shadow);
    }

    .daily-photo img {
      width: 100%;
      height: 520px;
      object-fit: cover;
    }

    .caption {
      margin: 0;
      padding: 14px 16px;
      color: var(--muted);
      font-size: 14px;
      line-height: 1.4;
    }

    .support-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 14px;
      margin: 26px 0;
    }

    .support-card,
    .help-card,
    .story,
    .step {
      border-radius: 8px;
      background: var(--white);
      box-shadow: 0 14px 32px rgba(32, 52, 40, 0.08);
    }

    .support-card {
      padding: 20px;
      border-top: 4px solid var(--clay);
    }

    .support-card strong {
      display: block;
      margin-bottom: 8px;
      color: var(--green-dark);
      font-size: 17px;
      line-height: 1.25;
    }

    .support-card p {
      margin: 0;
      color: var(--muted);
      font-size: 15px;
      line-height: 1.52;
    }

    .help-card {
      padding: 24px;
      border-left: 4px solid var(--blue);
    }

    .check-list {
      display: grid;
      gap: 10px;
      margin: 16px 0 0;
      padding: 0;
      list-style: none;
    }

    .check-list li {
      display: grid;
      grid-template-columns: 18px 1fr;
      gap: 10px;
      color: #3d4b45;
    }

    .check-list li::before {
      color: var(--green);
      font-weight: 700;
      content: "✓";
    }

    .stories-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 20px;
    }

    .story {
      overflow: hidden;
    }

    .story img {
      width: 100%;
      height: 280px;
      object-fit: cover;
    }

    .story-body {
      padding: 26px;
    }

    .story-meta {
      display: inline-flex;
      margin-bottom: 14px;
      color: var(--clay);
      font-size: 12px;
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
    }

    .story ul {
      margin: 16px 0 0;
      padding-left: 20px;
      color: #3d4b45;
    }

    .quote {
      margin: 20px 0 0;
      padding: 18px;
      border-left: 4px solid var(--green);
      background: #eef3ec;
      color: var(--green-dark);
      font-style: italic;
    }

    .steps-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 16px;
      counter-reset: step;
    }

    .step {
      position: relative;
      padding: 56px 20px 22px;
      overflow: hidden;
    }

    .step::before {
      position: absolute;
      top: 18px;
      left: 20px;
      width: 28px;
      height: 28px;
      display: grid;
      place-items: center;
      border-radius: 50%;
      color: var(--white);
      background: var(--green);
      font-size: 13px;
      font-weight: 700;
      counter-increment: step;
      content: counter(step);
    }

    .official-note {
      display: grid;
      grid-template-columns: 1fr auto;
      gap: 18px;
      align-items: center;
      margin-top: 24px;
      padding: 22px 24px;
      border-radius: 8px;
      background: #fbf4ee;
      color: #574941;
    }

    .official-note p {
      margin: 0;
    }

    .official-note a {
      color: var(--green-dark);
      font-weight: 700;
    }

    .team-band {
      display: grid;
      grid-template-columns: 0.86fr 1.14fr;
      gap: 34px;
      align-items: center;
    }

    .team-image {
      min-height: 430px;
      border-radius: 8px;
      background:
        linear-gradient(rgba(26, 45, 35, 0.08), rgba(26, 45, 35, 0.08)),
        url("https://images.unsplash.com/photo-1521737604893-d14cc237f11d?auto=format&fit=crop&w=1100&q=82") center / cover;
      box-shadow: var(--shadow);
    }

    .team-copy {
      padding: 10px 0;
    }

    .team-list {
      display: grid;
      gap: 14px;
      margin: 26px 0 0;
      padding: 0;
      list-style: none;
    }

    .team-list li {
      display: grid;
      grid-template-columns: 12px 1fr;
      gap: 13px;
      color: #3d4b45;
    }

    .team-list li::before {
      width: 8px;
      height: 8px;
      margin-top: 11px;
      border-radius: 50%;
      background: var(--clay);
      content: "";
    }

    .contact-layout {
      display: grid;
      grid-template-columns: 0.82fr 1.18fr;
      gap: 20px;
      align-items: stretch;
    }

    .contact-card,
    .map {
      border-radius: 8px;
      background: var(--white);
      box-shadow: var(--shadow);
    }

    .contact-card {
      padding: 30px;
    }

    .contact-lines {
      display: grid;
      gap: 15px;
      margin: 22px 0 26px;
    }

    .contact-line {
      display: flex;
      align-items: flex-start;
      gap: 12px;
      color: #3c4b44;
    }

    .contact-line svg {
      margin-top: 4px;
      color: var(--green);
    }

    .travel {
      margin: 0 0 26px;
      padding: 18px;
      border-left: 4px solid var(--clay);
      background: #fbf4ee;
      color: #574941;
    }

    .map {
      min-height: 430px;
      overflow: hidden;
    }

    .map iframe {
      width: 100%;
      height: 100%;
      min-height: 430px;
      border: 0;
      display: block;
    }

    footer {
      padding: 32px 0;
      color: rgba(255, 253, 248, 0.86);
      background: var(--green-dark);
    }

    .footer-inner {
      display: flex;
      justify-content: space-between;
      gap: 20px;
      font-size: 14px;
    }

    .footer-meta {
      display: grid;
      justify-items: end;
      gap: 6px;
    }

    .footer-meta a {
      color: rgba(255, 253, 248, 0.92);
      text-decoration: none;
      border-bottom: 1px solid rgba(255, 253, 248, 0.45);
    }

    .footer-meta a:hover,
    .footer-meta a:focus-visible {
      border-bottom-color: rgba(255, 253, 248, 0.92);
      outline: none;
    }

    @media (max-width: 900px) {
      .topbar {
        min-height: 88px;
      }

      .menu-toggle {
        display: inline-flex;
      }

      .nav {
        position: absolute;
        top: 88px;
        left: 20px;
        right: 20px;
        display: none;
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        padding: 10px;
        border: 1px solid var(--line);
        border-radius: 8px;
        background: var(--white);
        box-shadow: var(--shadow);
      }

      .nav.is-open {
        display: flex;
      }

      .nav a {
        padding: 13px 10px;
      }

      .hero {
        min-height: auto;
        padding: 128px 0 76px;
        background:
          linear-gradient(180deg, rgba(255, 253, 248, 0.96), rgba(255, 253, 248, 0.9) 52%, rgba(255, 253, 248, 0.68)),
          image-set(url("../images/hero.webp") type("image/webp"), url("../images/hero.jpg") type("image/jpeg")) top center / min(720px, 118%) auto;
        background-repeat: no-repeat;
        background-color: var(--white);
      }

      .strip-grid,
      .about-layout,
      .daily-layout,
      .team-band,
      .contact-layout {
        grid-template-columns: 1fr;
      }

      .service-grid {
        grid-template-columns: repeat(2, 1fr);
      }

      .service-cta,
      .official-note {
        align-items: flex-start;
      }

      .service-cta {
        flex-direction: column;
      }

      .official-note {
        grid-template-columns: 1fr;
      }

      .daily-photo {
        position: static;
      }

      .stories-grid,
      .steps-grid {
        grid-template-columns: 1fr 1fr;
      }

      .note-panel {
        max-width: 560px;
      }
    }

    @media (max-width: 640px) {
      .wrap {
        width: min(100% - 28px, 1120px);
      }

      .brand-logo {
        width: 132px;
        height: auto;
      }

      .lang-links {
        min-width: 58px;
      }

      .hero {
        padding-top: 270px;
        background:
          linear-gradient(180deg, rgba(255, 253, 248, 0.02), rgba(255, 253, 248, 0.24) 26%, rgba(255, 253, 248, 0.9) 42%, rgba(255, 253, 248, 1) 52%, rgba(255, 253, 248, 1) 100%),
          image-set(url("../images/hero-mob.webp") type("image/webp"), url("../images/hero-mob.jpg") type("image/jpeg"));
        background-size: auto, 100% auto;
        background-position: center top, 50% 0;
        background-repeat: no-repeat, no-repeat;
        background-color: var(--white);
      }

      .actions,
      .actions .button {
        width: 100%;
      }

      section {
        padding: 66px 0;
      }

      .strip-grid,
      .service-grid,
      .support-grid,
      .stories-grid,
      .steps-grid {
        grid-template-columns: 1fr;
      }

      .strip-item {
        min-height: auto;
        padding: 22px;
      }

      .team-image,
      .map,
      .map iframe {
        min-height: 330px;
      }

      .daily-photo img {
        height: 360px;
      }

      .footer-inner {
        flex-direction: column;
      }

      .footer-meta {
        justify-items: start;
      }
    }
  
