@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Roboto:wght@300;400;500;700&display=swap');

:root {
  --tile-primary: #2D6A4F;
  --tile-secondary: #40916C;
  --tile-accent: #D4A03C;
  --tile-background: #FAFAF5;
  --tile-surface: #FFFFFF;
  --tile-text: #1B2A1B;
  --tile-text-light: #5C6B5C;
  --tile-border: #D5DFD5;
  --tile-hero-overlay: linear-gradient(160deg, rgba(45, 106, 79, 0.88), rgba(64, 145, 108, 0.55));
  --tile-shadow: 0 24px 70px rgba(27, 42, 27, 0.08);
  --tile-radius-lg: 30% 70% 70% 30% / 30% 30% 70% 70%;
  --tile-radius-md: 21% 79% 31% 69% / 63% 30% 70% 37%;
  --tile-radius-sm: 58% 42% 35% 65% / 38% 61% 39% 62%;
  --tile-nav-width: 240px;
  --tile-gutter: clamp(1.25rem, 2.5vw, 2.5rem);
  --tile-max-width: 1480px;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  color: var(--tile-text);
  background:
    repeating-linear-gradient(
      0deg,
      rgba(213, 223, 213, 0.18) 0,
      rgba(213, 223, 213, 0.18) 1px,
      transparent 1px,
      transparent 15px
    ),
    var(--tile-background);
  font-family: 'Roboto', sans-serif;
  font-weight: 400;
  line-height: 1.6;
}

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

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

button,
input,
textarea,
select {
  font: inherit;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  color: var(--tile-primary);
  font-family: 'Bebas Neue', sans-serif;
  font-weight: 400;
  letter-spacing: 0.06em;
  line-height: 0.95;
}

p {
  margin: 0;
}

body.tile-nav-open,
body.tile-modal-open {
  overflow: hidden;
}

.tile-site {
  min-height: 100vh;
}

.tile-nav-toggle {
  position: fixed;
  top: 1rem;
  right: 1rem;
  z-index: 1200;
  display: none;
  width: 3.25rem;
  height: 3.25rem;
  padding: 0;
  border: 2px dashed var(--tile-border);
  border-radius: 38% 62% 54% 46% / 47% 39% 61% 53%;
  background: var(--tile-surface);
  box-shadow: var(--tile-shadow);
  color: var(--tile-primary);
  cursor: pointer;
}

.tile-nav-toggle-line,
.tile-nav-toggle::before,
.tile-nav-toggle::after {
  position: absolute;
  left: 0.8rem;
  width: 1.6rem;
  height: 2px;
  background: currentColor;
  content: "";
  transition: transform 0.3s ease, opacity 0.3s ease;
}

.tile-nav-toggle-line {
  top: 1.55rem;
}

.tile-nav-toggle::before {
  top: 1.1rem;
}

.tile-nav-toggle::after {
  top: 2rem;
}

body.tile-nav-open .tile-nav-toggle-line {
  opacity: 0;
}

body.tile-nav-open .tile-nav-toggle::before {
  transform: translateY(0.45rem) rotate(45deg);
}

body.tile-nav-open .tile-nav-toggle::after {
  transform: translateY(-0.45rem) rotate(-45deg);
}

.tile-nav {
  position: fixed;
  inset: 0 auto 0 0;
  z-index: 1100;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  width: var(--tile-nav-width);
  padding: 2rem 1.25rem;
  background:
    radial-gradient(circle at top, rgba(64, 145, 108, 0.12), transparent 50%),
    var(--tile-surface);
  border-right: 1px solid var(--tile-border);
}

.tile-nav-panel {
  display: grid;
  gap: 1.5rem;
}

.tile-nav-brand {
  display: grid;
  gap: 0.45rem;
}

.tile-nav-title {
  font-size: clamp(2.25rem, 4vw, 3.5rem);
}

.tile-nav-subtitle,
.tile-nav-meta,
.tile-language-toggle {
  color: var(--tile-text-light);
}

.tile-nav-links {
  display: grid;
  gap: 0.65rem;
}

.tile-nav-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.9rem 1rem;
  border: 2px dashed transparent;
  border-radius: 42% 58% 47% 53% / 58% 41% 59% 42%;
  transition: border-color 0.25s ease, transform 0.25s ease, color 0.25s ease, background 0.25s ease;
}

.tile-nav-link::after {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.15rem;
  letter-spacing: 0.1em;
  content: "00";
  color: var(--tile-accent);
}

.tile-nav-link:hover,
.tile-nav-link:focus-visible,
.tile-nav-link[aria-current="page"] {
  color: var(--tile-primary);
  background: rgba(64, 145, 108, 0.08);
  border-color: var(--tile-border);
  transform: rotate(-1deg);
}

.tile-nav-footer {
  display: grid;
  gap: 0.65rem;
}

.tile-language-switch {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  width: fit-content;
  padding: 0.3rem;
  border: 1px solid var(--tile-border);
  border-radius: 999px;
  background: rgba(64, 145, 108, 0.06);
}

.tile-language-option {
  min-width: 3rem;
  padding: 0.4rem 0.75rem;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--tile-text-light);
  cursor: pointer;
  transition: background 0.25s ease, color 0.25s ease;
}

.tile-language-option.is-active {
  background: var(--tile-primary);
  color: var(--tile-surface);
}

.tile-main {
  margin-left: var(--tile-nav-width);
}

.tile-shell {
  width: min(calc(100% - 3rem), var(--tile-max-width));
  margin: 0 auto;
}

.tile-page {
  padding: 2rem 0 4rem;
}

.tile-page-head {
  display: grid;
  gap: 1rem;
  margin-bottom: 2rem;
}

.tile-page-kicker {
  color: var(--tile-accent);
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.tile-grid {
  display: grid;
  gap: var(--tile-gutter);
}

.tile-home-grid {
  grid-template-columns: repeat(12, minmax(0, 1fr));
  align-items: start;
}

.tile-block {
  position: relative;
  overflow: hidden;
  min-height: 240px;
  padding: clamp(1.25rem, 2vw, 2rem);
  background: var(--tile-surface);
  border: 1px solid var(--tile-border);
  box-shadow: var(--tile-shadow);
}

.tile-block::before {
  position: absolute;
  inset: 0;
  pointer-events: none;
  content: "";
}

.tile-block:hover {
  transform: rotate(-1deg);
}

.tile-hero {
  grid-column: 1 / -1;
  min-height: clamp(27rem, 70vh, 48rem);
  display: flex;
  align-items: flex-end;
  border-radius: 2.5rem;
  background:
    url('images/hero-1.jpg') center/cover no-repeat,
    var(--tile-primary);
}

.tile-hero::before {
  inset: auto 0 0 0;
  height: 40%;
  background: rgba(27, 42, 27, 0.2);
}

.tile-hero-copy {
  position: relative;
  z-index: 1;
  width: min(34rem, 100%);
  color: var(--tile-surface);
}

.tile-hero-title {
  color: inherit;
  font-size: clamp(4.5rem, 10vw, 9rem);
  text-shadow: 0 12px 36px rgba(0, 0, 0, 0.28);
}

.tile-hero-copy p {
  max-width: 26rem;
  font-size: 1.05rem;
  text-shadow: 0 8px 24px rgba(0, 0, 0, 0.24);
}

.tile-button,
.tile-inline-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  width: fit-content;
  margin-top: 1rem;
  padding: 0.95rem 1.3rem;
  border: 0;
  border-radius: 43% 57% 58% 42% / 53% 40% 60% 47%;
  background: var(--tile-accent);
  color: var(--tile-text);
  cursor: pointer;
  transition: transform 0.25s ease, background 0.25s ease;
}

.tile-button:hover,
.tile-inline-button:hover,
.tile-button:focus-visible,
.tile-inline-button:focus-visible {
  background: #c8942d;
  transform: rotate(1deg);
}

.tile-programs {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--tile-gutter);
}

.tile-program-tile {
  min-height: 20rem;
  padding: 0;
  border-radius: var(--tile-radius-lg);
  isolation: isolate;
}

.tile-program-tile::before {
  background: linear-gradient(180deg, transparent 42%, rgba(27, 42, 27, 0.72) 100%);
  opacity: 0;
  transition: opacity 0.3s ease;
}

.tile-program-tile:hover::before {
  opacity: 1;
}

.tile-program-tile:nth-child(1) {
  background: url('images/community-1.jpg') center/cover no-repeat;
}

.tile-program-tile:nth-child(2) {
  background: url('images/community-2.jpg') center/cover no-repeat;
}

.tile-program-tile:nth-child(3) {
  background: url('images/community-3.jpg') center/cover no-repeat;
}

.tile-program-tile:nth-child(4) {
  background: url('images/community-4.jpg') center/cover no-repeat;
}

.tile-program-copy {
  position: absolute;
  inset: auto 1.25rem 1.25rem;
  z-index: 1;
  display: grid;
  gap: 0.4rem;
  color: var(--tile-surface);
  opacity: 0;
  transform: translateY(0.75rem);
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.tile-program-tile:hover .tile-program-copy {
  opacity: 1;
  transform: translateY(0);
}

.tile-mission {
  grid-column: 1 / -1;
  min-height: 16rem;
  display: grid;
  align-content: center;
  gap: 1rem;
  padding-inline: clamp(1.5rem, 4vw, 4rem);
  border: 2px dashed var(--tile-border);
  border-radius: 5rem 2rem 4rem 3rem / 2.5rem 4rem 2.5rem 4rem;
}

.tile-mission-title {
  font-size: clamp(3rem, 6vw, 5.5rem);
}

.tile-mission p {
  max-width: 58rem;
  color: var(--tile-text-light);
  font-size: 1.1rem;
}

.tile-stories {
  grid-column: 1 / span 8;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--tile-gutter);
}

.tile-story-tile {
  min-height: 18rem;
  padding: 0;
  border-radius: var(--tile-radius-sm);
}

.tile-story-tile:nth-child(1) {
  background: url('images/scene-1.jpg') center/cover no-repeat;
}

.tile-story-tile:nth-child(2) {
  background: url('images/portrait-1.jpg') center/cover no-repeat;
}

.tile-story-tile:nth-child(3) {
  background: url('images/portrait-2.jpg') center/cover no-repeat;
}

.tile-story-tile:nth-child(4) {
  background: url('images/scene-2.jpg') center/cover no-repeat;
}

.tile-story-tile:nth-child(5) {
  background: url('images/portrait-3.jpg') center/cover no-repeat;
}

.tile-story-tile:nth-child(6) {
  background: url('images/scene-3.jpg') center/cover no-repeat;
}

.tile-story-tile::before {
  background: linear-gradient(180deg, transparent 40%, rgba(27, 42, 27, 0.6) 100%);
  opacity: 0;
  transition: opacity 0.25s ease;
}

.tile-story-tile:hover::before {
  opacity: 1;
}

.tile-story-caption {
  position: absolute;
  inset: auto 1rem 1rem;
  z-index: 1;
  color: var(--tile-surface);
  opacity: 0;
  transition: opacity 0.25s ease;
}

.tile-story-tile:hover .tile-story-caption {
  opacity: 1;
}

.tile-impact-strip {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  padding: 0;
  background: var(--tile-border);
  border-radius: 2rem;
}

.tile-impact-item {
  min-height: 12rem;
  display: grid;
  place-items: center;
  gap: 0.35rem;
  padding: 1.5rem;
  background: var(--tile-surface);
  text-align: center;
}

.tile-impact-value {
  color: var(--tile-primary);
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(3rem, 5vw, 5rem);
  letter-spacing: 0.05em;
}

.tile-impact-label {
  color: var(--tile-text-light);
}

.tile-team-tile {
  grid-column: 9 / -1;
  min-height: 40rem;
  display: grid;
  gap: 1rem;
}

.tile-team-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.tile-team-member {
  position: relative;
  min-height: 12rem;
  overflow: hidden;
  border-radius: 2rem;
  background-position: center;
  background-size: cover;
}

.tile-team-member:nth-child(1) { background-image: url('images/portrait-1.jpg'); }
.tile-team-member:nth-child(2) { background-image: url('images/portrait-2.jpg'); }
.tile-team-member:nth-child(3) { background-image: url('images/portrait-3.jpg'); }
.tile-team-member:nth-child(4) { background-image: url('images/portrait-4.jpg'); }

.tile-team-member::before {
  position: absolute;
  inset: 0;
  background: rgba(27, 42, 27, 0.62);
  opacity: 0;
  transition: opacity 0.25s ease;
  content: "";
}

.tile-team-member:hover::before {
  opacity: 1;
}

.tile-team-overlay {
  position: absolute;
  inset: auto 1rem 1rem;
  z-index: 1;
  color: var(--tile-surface);
  opacity: 0;
  transform: translateY(0.6rem);
  transition: opacity 0.25s ease, transform 0.25s ease;
}

.tile-team-member:hover .tile-team-overlay {
  opacity: 1;
  transform: translateY(0);
}

.tile-events {
  grid-column: 1 / span 5;
  min-height: 24rem;
  display: grid;
  align-content: end;
  border-radius: 3rem;
  background:
    linear-gradient(180deg, rgba(27, 42, 27, 0.05), rgba(27, 42, 27, 0.65)),
    url('images/hero-2.jpg') center/cover no-repeat;
}

.tile-events-copy {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.6rem;
  color: var(--tile-surface);
}

.tile-events-copy h3 {
  color: inherit;
  font-size: clamp(2.5rem, 5vw, 4rem);
}

.tile-resources {
  grid-column: 6 / span 3;
  min-height: 24rem;
  display: grid;
  align-content: start;
  gap: 1rem;
  border-radius: var(--tile-radius-md);
}

.tile-resource-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  cursor: pointer;
}

.tile-resource-icon,
.tile-contact-icon {
  display: grid;
  place-items: center;
  width: 4.25rem;
  height: 4.25rem;
  border: 2px dashed var(--tile-secondary);
  border-radius: 41% 59% 62% 38% / 48% 38% 62% 52%;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.45rem;
  color: var(--tile-primary);
}

.tile-resource-panel {
  display: grid;
  gap: 0.8rem;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.35s ease;
}

.tile-resources.is-open .tile-resource-panel {
  max-height: 20rem;
}

.tile-resource-link {
  color: var(--tile-secondary);
}

.tile-partners {
  grid-column: 1 / -1;
  min-height: 8rem;
  display: flex;
  align-items: center;
  gap: 1.5rem;
  padding-inline: clamp(1rem, 3vw, 2rem);
  border-style: dashed;
  border-radius: 999px;
  white-space: nowrap;
  overflow-x: auto;
}

.tile-partner-logo {
  flex: 0 0 auto;
  padding: 0.8rem 1.1rem;
  color: var(--tile-text-light);
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.6rem;
  letter-spacing: 0.08em;
}

.tile-map {
  grid-column: 9 / span 2;
  min-height: 24rem;
  display: grid;
  align-content: end;
  border-radius: 2rem;
  background:
    linear-gradient(0deg, rgba(45, 106, 79, 0.08), rgba(45, 106, 79, 0.08)),
    url('images/hero-3.jpg') center/cover no-repeat;
}

.tile-map-graphic {
  position: absolute;
  inset: 1rem;
  background:
    radial-gradient(circle at 48% 52%, rgba(212, 160, 60, 0.92) 0, rgba(212, 160, 60, 0.92) 5px, transparent 6px),
    linear-gradient(rgba(255, 255, 255, 0.44) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.44) 1px, transparent 1px);
  background-size: auto, 48px 48px, 48px 48px;
  border-radius: 1.75rem;
  opacity: 0.92;
}

.tile-map-copy {
  position: relative;
  z-index: 1;
  margin-top: auto;
  padding: 1rem;
  background: rgba(250, 250, 245, 0.92);
  border-radius: 1.5rem;
}

.tile-contact {
  grid-column: 11 / -1;
  min-height: 24rem;
  display: grid;
  place-content: center;
  justify-items: center;
  gap: 1rem;
  text-align: center;
  border-radius: var(--tile-radius-md);
}

.tile-contact-trigger {
  display: grid;
  place-items: center;
  gap: 1rem;
  width: 100%;
  border: 0;
  background: transparent;
  color: inherit;
  cursor: pointer;
}

.tile-contact-copy {
  color: var(--tile-text-light);
}

.tile-wave-divider {
  width: 100%;
  height: 5rem;
  margin: 4rem 0;
  background:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 180' preserveAspectRatio='none'%3E%3Cpath fill='%23D5DFD5' d='M0 85c118 0 118-52 236-52s118 68 236 68 118-67 236-67 118 73 236 73 118-55 236-55 118 45 236 45v83H0Z'/%3E%3C/svg%3E")
    center/cover no-repeat;
}

.tile-about-grid,
.tile-program-page-grid,
.tile-contact-grid,
.tile-team-page-grid {
  grid-template-columns: repeat(12, minmax(0, 1fr));
  align-items: start;
}

.tile-about-hero,
.tile-contact-hero {
  grid-column: 1 / -1;
  min-height: 25rem;
  border-radius: 3rem;
  background-position: center;
  background-size: cover;
}

.tile-about-hero {
  background-image: linear-gradient(180deg, rgba(27, 42, 27, 0.12), rgba(27, 42, 27, 0.52)), url('images/scene-1.jpg');
}

.tile-contact-hero {
  background-image: linear-gradient(180deg, rgba(27, 42, 27, 0.18), rgba(27, 42, 27, 0.56)), url('images/hero-2.jpg');
}

.tile-about-photo,
.tile-program-photo,
.tile-contact-photo {
  min-height: 22rem;
  border-radius: var(--tile-radius-lg);
  background-position: center;
  background-size: cover;
}

.tile-about-photo:nth-of-type(1) { background-image: url('images/scene-2.jpg'); }
.tile-about-photo:nth-of-type(2) { background-image: url('images/community-2.jpg'); }
.tile-about-photo:nth-of-type(3) { background-image: url('images/scene-3.jpg'); }

.tile-about-story {
  display: grid;
  gap: 1rem;
  align-content: center;
}

.tile-about-grid .tile-about-story:nth-of-type(1) { grid-column: 1 / span 5; }
.tile-about-grid .tile-about-photo:nth-of-type(1) { grid-column: 6 / -1; }
.tile-about-grid .tile-about-photo:nth-of-type(2) { grid-column: 1 / span 4; }
.tile-about-grid .tile-about-story:nth-of-type(2) { grid-column: 5 / -1; }
.tile-about-grid .tile-about-photo:nth-of-type(3) { grid-column: 1 / span 5; }
.tile-about-grid .tile-about-story:nth-of-type(3) { grid-column: 6 / -1; }

.tile-program-card {
  min-height: 28rem;
  display: grid;
  grid-template-rows: 1fr auto;
  padding: 0;
  border-radius: 2.5rem;
  overflow: hidden;
}

.tile-program-card:nth-child(1) { background-image: url('images/community-1.jpg'); }
.tile-program-card:nth-child(2) { background-image: url('images/community-3.jpg'); }
.tile-program-card:nth-child(3) { background-image: url('images/scene-1.jpg'); }
.tile-program-card:nth-child(4) { background-image: url('images/scene-2.jpg'); }

.tile-program-card {
  background-position: center;
  background-size: cover;
}

.tile-program-card-copy {
  padding: 1.4rem;
  background: rgba(250, 250, 245, 0.92);
}

.tile-program-page-grid .tile-program-card:nth-child(1) { grid-column: 1 / span 6; }
.tile-program-page-grid .tile-program-card:nth-child(2) { grid-column: 7 / -1; }
.tile-program-page-grid .tile-program-card:nth-child(3) { grid-column: 1 / span 6; }
.tile-program-page-grid .tile-program-card:nth-child(4) { grid-column: 7 / -1; }

.tile-team-page-grid .tile-team-card {
  grid-column: span 3;
}

.tile-team-card {
  padding: 0;
  overflow: hidden;
  border-radius: 2rem;
}

.tile-team-card-photo {
  min-height: 21rem;
  background-position: center;
  background-size: cover;
}

.tile-team-card:nth-child(1) .tile-team-card-photo { background-image: url('images/portrait-1.jpg'); }
.tile-team-card:nth-child(2) .tile-team-card-photo { background-image: url('images/portrait-2.jpg'); }
.tile-team-card:nth-child(3) .tile-team-card-photo { background-image: url('images/portrait-3.jpg'); }
.tile-team-card:nth-child(4) .tile-team-card-photo { background-image: url('images/portrait-4.jpg'); }
.tile-team-card:nth-child(5) .tile-team-card-photo { background-image: url('images/portrait-5.jpg'); }
.tile-team-card:nth-child(6) .tile-team-card-photo { background-image: url('images/portrait-6.jpg'); }
.tile-team-card:nth-child(7) .tile-team-card-photo { background-image: url('images/portrait-7.jpg'); }
.tile-team-card:nth-child(8) .tile-team-card-photo { background-image: url('images/portrait-8.jpg'); }

.tile-team-card-copy {
  display: grid;
  gap: 0.4rem;
  padding: 1.25rem;
}

.tile-team-role {
  color: var(--tile-text-light);
}

.tile-contact-grid .tile-contact-form {
  grid-column: 1 / span 7;
}

.tile-contact-grid .tile-contact-aside {
  grid-column: 8 / -1;
}

.tile-contact-form,
.tile-contact-aside {
  display: grid;
  gap: 1rem;
}

.tile-field {
  display: grid;
  gap: 0.45rem;
}

.tile-field input,
.tile-field textarea {
  width: 100%;
  padding: 0.95rem 1rem;
  border: 1px solid var(--tile-border);
  border-radius: 1.3rem;
  background: rgba(255, 255, 255, 0.86);
  color: var(--tile-text);
}

.tile-field textarea {
  min-height: 10rem;
  resize: vertical;
}

.tile-contact-list {
  display: grid;
  gap: 0.75rem;
  color: var(--tile-text-light);
}

.tile-contact-list strong {
  color: var(--tile-primary);
}

.tile-modal {
  position: fixed;
  inset: 0;
  z-index: 1300;
  display: grid;
  place-items: center;
  padding: 1.5rem;
  background: rgba(27, 42, 27, 0.55);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.25s ease, visibility 0.25s ease;
}

.tile-modal.is-open {
  opacity: 1;
  visibility: visible;
}

.tile-modal-card {
  width: min(38rem, 100%);
  padding: 2rem;
  background: var(--tile-surface);
  border-radius: 2rem;
  box-shadow: var(--tile-shadow);
}

.tile-modal-close {
  margin-left: auto;
  padding: 0.5rem 0.9rem;
  border: 0;
  border-radius: 999px;
  background: rgba(64, 145, 108, 0.12);
  color: var(--tile-primary);
  cursor: pointer;
}

.tile-modal-body {
  display: grid;
  gap: 0.9rem;
  margin-top: 1rem;
}

.fade-in {
  opacity: 0;
  transform: translateY(2rem);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.fade-in.is-visible {
  opacity: 1;
  transform: translateY(0);
}

[data-lang] [data-en] {
  display: none;
}

[data-lang="en"] [data-en] {
  display: revert;
}

[data-lang="en"] [data-sv] {
  display: none;
}

[data-lang="sv"] [data-sv] {
  display: revert;
}

@media (max-width: 1180px) {
  .tile-programs,
  .tile-stories,
  .tile-impact-strip,
  .tile-team-grid,
  .tile-about-grid,
  .tile-program-page-grid,
  .tile-team-page-grid,
  .tile-contact-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .tile-team-tile,
  .tile-events,
  .tile-resources,
  .tile-map,
  .tile-contact,
  .tile-about-grid > *,
  .tile-program-page-grid > *,
  .tile-team-page-grid > *,
  .tile-contact-grid > * {
    grid-column: 1 / -1;
  }

  .tile-stories {
    grid-column: 1 / -1;
  }

  .tile-programs {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 920px) {
  .tile-nav-toggle {
    display: block;
  }

  .tile-nav {
    transform: translateX(-102%);
    transition: transform 0.3s ease;
    width: min(86vw, 320px);
    box-shadow: 0 20px 50px rgba(27, 42, 27, 0.16);
  }

  body.tile-nav-open .tile-nav {
    transform: translateX(0);
  }

  .tile-main {
    margin-left: 0;
    padding-top: 4.5rem;
  }

  .tile-shell {
    width: min(calc(100% - 1.5rem), var(--tile-max-width));
  }

  .tile-home-grid,
  .tile-programs,
  .tile-stories,
  .tile-impact-strip,
  .tile-team-grid,
  .tile-about-grid,
  .tile-program-page-grid,
  .tile-team-page-grid,
  .tile-contact-grid {
    grid-template-columns: 1fr;
  }

  .tile-hero-title {
    font-size: clamp(3.8rem, 16vw, 6.2rem);
  }

  .tile-impact-item {
    min-height: 9rem;
  }

  .tile-partners {
    border-radius: 2rem;
  }
}

@media (max-width: 640px) {
  .tile-page {
    padding-bottom: 3rem;
  }

  .tile-block {
    min-height: 220px;
    padding: 1rem;
  }

  .tile-hero {
    min-height: 24rem;
    border-radius: 2rem;
  }

  .tile-program-tile,
  .tile-story-tile,
  .tile-map,
  .tile-contact,
  .tile-resources,
  .tile-events {
    min-height: 18rem;
  }

  .tile-impact-strip {
    gap: 0.75rem;
    background: transparent;
  }

  .tile-impact-item {
    border: 1px solid var(--tile-border);
    box-shadow: var(--tile-shadow);
  }
}
