/* latin */
@font-face {
  font-family: "Fredoka";
  font-style: normal;
  font-weight: 300 700;
  font-stretch: 75% 125%;
  font-display: block;
  src: url(fonts/fredoka.woff2) format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 300 800;
  font-stretch: 75% 100%;
  font-display: block;
  src: url(fonts/opensans.woff2) format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "Open Sans";
  font-style: italic;
  font-weight: 300 800;
  font-stretch: 75% 100%;
  font-display: block;
  src: url(fonts/opensans_italic.woff2) format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* symbols */
@font-face {
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 300 800;
  font-stretch: 75% 100%;
  font-display: swap;
  src: url(fonts/opensans_symbols.woff2) format("woff2");
  unicode-range: U+0001-000C, U+000E-001F, U+007F-009F, U+20DD-20E0, U+20E2-20E4, U+2150-218F, U+2190, U+2192, U+2194-2199, U+21AF, U+21E6-21F0, U+21F3, U+2218-2219, U+2299, U+22C4-22C6, U+2300-243F, U+2440-244A, U+2460-24FF, U+25A0-27BF, U+2800-28FF, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B00-2BFF, U+4DC0-4DFF, U+FFF9-FFFB, U+10140-1018E, U+10190-1019C, U+101A0, U+101D0-101FD, U+102E0-102FB, U+10E60-10E7E, U+1D2C0-1D2D3, U+1D2E0-1D37F, U+1F000-1F0FF, U+1F100-1F1AD, U+1F1E6-1F1FF, U+1F30D-1F30F, U+1F315, U+1F31C, U+1F31E, U+1F320-1F32C, U+1F336, U+1F378, U+1F37D, U+1F382, U+1F393-1F39F, U+1F3A7-1F3A8, U+1F3AC-1F3AF, U+1F3C2, U+1F3C4-1F3C6, U+1F3CA-1F3CE, U+1F3D4-1F3E0, U+1F3ED, U+1F3F1-1F3F3, U+1F3F5-1F3F7, U+1F408, U+1F415, U+1F41F, U+1F426, U+1F43F, U+1F441-1F442, U+1F444, U+1F446-1F449, U+1F44C-1F44E, U+1F453, U+1F46A, U+1F47D, U+1F4A3, U+1F4B0, U+1F4B3, U+1F4B9, U+1F4BB, U+1F4BF, U+1F4C8-1F4CB, U+1F4D6, U+1F4DA, U+1F4DF, U+1F4E3-1F4E6, U+1F4EA-1F4ED, U+1F4F7, U+1F4F9-1F4FB, U+1F4FD-1F4FE, U+1F503, U+1F507-1F50B, U+1F50D, U+1F512-1F513, U+1F53E-1F54A, U+1F54F-1F5FA, U+1F610, U+1F650-1F67F, U+1F687, U+1F68D, U+1F691, U+1F694, U+1F698, U+1F6AD, U+1F6B2, U+1F6B9-1F6BA, U+1F6BC, U+1F6C6-1F6CF, U+1F6D3-1F6D7, U+1F6E0-1F6EA, U+1F6F0-1F6F3, U+1F6F7-1F6FC, U+1F700-1F7FF, U+1F800-1F80B, U+1F810-1F847, U+1F850-1F859, U+1F860-1F887, U+1F890-1F8AD, U+1F8B0-1F8B1, U+1F900-1F90B, U+1F93B, U+1F946, U+1F984, U+1F996, U+1F9E9, U+1FA00-1FA6F, U+1FA70-1FA7C, U+1FA80-1FA88, U+1FA90-1FABD, U+1FABF-1FAC5, U+1FACE-1FADB, U+1FAE0-1FAE8, U+1FAF0-1FAF8, U+1FB00-1FBFF;
}
@font-face {
  font-family: "Open Sans";
  font-style: italic;
  font-weight: 300 800;
  font-stretch: 75% 100%;
  font-display: swap;
  src: url(fonts/opensans_symbols_italic.woff2) format("woff2");
  unicode-range: U+0001-000C, U+000E-001F, U+007F-009F, U+20DD-20E0, U+20E2-20E4, U+2150-218F, U+2190, U+2192, U+2194-2199, U+21AF, U+21E6-21F0, U+21F3, U+2218-2219, U+2299, U+22C4-22C6, U+2300-243F, U+2440-244A, U+2460-24FF, U+25A0-27BF, U+2800-28FF, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B00-2BFF, U+4DC0-4DFF, U+FFF9-FFFB, U+10140-1018E, U+10190-1019C, U+101A0, U+101D0-101FD, U+102E0-102FB, U+10E60-10E7E, U+1D2C0-1D2D3, U+1D2E0-1D37F, U+1F000-1F0FF, U+1F100-1F1AD, U+1F1E6-1F1FF, U+1F30D-1F30F, U+1F315, U+1F31C, U+1F31E, U+1F320-1F32C, U+1F336, U+1F378, U+1F37D, U+1F382, U+1F393-1F39F, U+1F3A7-1F3A8, U+1F3AC-1F3AF, U+1F3C2, U+1F3C4-1F3C6, U+1F3CA-1F3CE, U+1F3D4-1F3E0, U+1F3ED, U+1F3F1-1F3F3, U+1F3F5-1F3F7, U+1F408, U+1F415, U+1F41F, U+1F426, U+1F43F, U+1F441-1F442, U+1F444, U+1F446-1F449, U+1F44C-1F44E, U+1F453, U+1F46A, U+1F47D, U+1F4A3, U+1F4B0, U+1F4B3, U+1F4B9, U+1F4BB, U+1F4BF, U+1F4C8-1F4CB, U+1F4D6, U+1F4DA, U+1F4DF, U+1F4E3-1F4E6, U+1F4EA-1F4ED, U+1F4F7, U+1F4F9-1F4FB, U+1F4FD-1F4FE, U+1F503, U+1F507-1F50B, U+1F50D, U+1F512-1F513, U+1F53E-1F54A, U+1F54F-1F5FA, U+1F610, U+1F650-1F67F, U+1F687, U+1F68D, U+1F691, U+1F694, U+1F698, U+1F6AD, U+1F6B2, U+1F6B9-1F6BA, U+1F6BC, U+1F6C6-1F6CF, U+1F6D3-1F6D7, U+1F6E0-1F6EA, U+1F6F0-1F6F3, U+1F6F7-1F6FC, U+1F700-1F7FF, U+1F800-1F80B, U+1F810-1F847, U+1F850-1F859, U+1F860-1F887, U+1F890-1F8AD, U+1F8B0-1F8B1, U+1F900-1F90B, U+1F93B, U+1F946, U+1F984, U+1F996, U+1F9E9, U+1FA00-1FA6F, U+1FA70-1FA7C, U+1FA80-1FA88, U+1FA90-1FABD, U+1FABF-1FAC5, U+1FACE-1FADB, U+1FAE0-1FAE8, U+1FAF0-1FAF8, U+1FB00-1FBFF;
}
/* greek */
@font-face {
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 300 800;
  font-stretch: 75% 100%;
  font-display: swap;
  src: url(fonts/opensans_greek.woff2) format("woff2");
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: "Open Sans";
  font-style: italic;
  font-weight: 300 800;
  font-stretch: 75% 100%;
  font-display: swap;
  src: url(fonts/opensans_greek_italic.woff2) format("woff2");
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* greek-ext */
@font-face {
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 300 800;
  font-stretch: 75% 100%;
  font-display: swap;
  src: url(fonts/opensans_greek_ext.woff2) format("woff2");
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: "Open Sans";
  font-style: italic;
  font-weight: 300 800;
  font-stretch: 75% 100%;
  font-display: swap;
  src: url(fonts/opensans_greek_ext_italic.woff2) format("woff2");
  unicode-range: U+1F00-1FFF;
}
/* hebrew */
@font-face {
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 300 800;
  font-stretch: 75% 100%;
  font-display: swap;
  src: url(fonts/opensans_hebrew.woff2) format("woff2");
  unicode-range: U+0590-05FF, U+200C-2010, U+20AA, U+25CC, U+FB1D-FB4F;
}
@font-face {
  font-family: "Open Sans";
  font-style: italic;
  font-weight: 300 800;
  font-stretch: 75% 100%;
  font-display: swap;
  src: url(fonts/opensans_hebrew_italic.woff2) format("woff2");
  unicode-range: U+0590-05FF, U+200C-2010, U+20AA, U+25CC, U+FB1D-FB4F;
}
html {
  --blue: #0050a0;
  --green: #8cbe14;
  --blueO: #4d85bd;
  --greenO: #afd25b;
  --mix: #2a7176;
  --blueD: #004080;
  background: #eee;
  font-family: "Open Sans", sans-serif;
}

body {
  display: flex;
  flex-direction: column;
  gap: 2em;
  width: 100%;
  max-width: 80em;
  min-height: 100dvh;
  margin: 0 auto;
  box-sizing: border-box;
  -webkit-text-size-adjust: none;
     -moz-text-size-adjust: none;
          text-size-adjust: none;
}

p {
  margin: 0 0 1em;
  line-height: 1.4em;
}

a {
  display: inline-flex;
  align-items: center;
  color: inherit;
  text-decoration: none;
}

a[href^=https]:after {
  content: "";
  display: inline-block;
  width: 1.2em;
  height: 1.2em;
  margin-left: 0.2em;
  background-color: transparent;
  background-image: url("images/external-link.svg");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
}

img {
  max-width: 100%;
}

time {
  display: contents;
}

header {
  padding: 2em 0 0;
  border-bottom-left-radius: 1em;
  border-bottom-right-radius: 1em;
  background: white;
}
header > * {
  padding: 0 2rem;
}
header img {
  height: 8em;
  max-height: 17dvw;
}
header nav {
  position: relative;
  display: flex;
  justify-content: space-between;
  margin: 1.5em 0 0;
  padding: 0.3em calc(2rem - 1.1em);
  border-bottom-left-radius: 1em;
  border-bottom-right-radius: 1em;
  color: white;
  background-color: var(--blueO);
  font-family: "Fredoka";
  font-weight: 500;
  font-size: clamp(0.9em, 2.5vw, 1.2em);
  line-height: 1em;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
header nav ul {
  display: flex;
  align-content: flex-start;
  align-items: center;
  flex-direction: row;
  flex-wrap: wrap;
  width: 100%;
  margin: 0;
  padding: 0;
  list-style: none;
  overflow: hidden;
}
header nav li {
  padding: 0 0.4em;
}
header nav button, header nav a {
  display: block;
  padding: 0.7em 0.7em;
  border-radius: 0.5em;
  border: 0.1em solid transparent;
  outline: none;
  background: transparent;
  font-size: inherit;
  font-weight: inherit;
  color: inherit;
  white-space: nowrap;
  cursor: pointer;
}
header nav a:focus-within, header nav a:hover,
header nav button:focus-within {
  border-color: var(--green);
  box-shadow: inset 0 0 0.2em 0em var(--mix);
}
header nav div.sub {
  padding: 0 0.4em;
}
header nav div.sub > div {
  position: absolute;
  top: calc(100% - 0.3em);
  right: calc(2rem - 0.7em);
  max-height: 100dvh;
  transition: max-height 0.2s ease-in-out;
  overflow: hidden;
}
header nav div.sub ul {
  display: flex;
  flex-direction: column;
  padding: 0.4em;
  background-color: var(--mix);
  box-shadow: inset 0 0 0.4em 0.3em var(--blueO);
}
header nav div.sub:not(:has(li)) {
  visibility: hidden;
}
header nav div.sub:not(:focus-within, :hover) > div {
  max-height: 0;
}

main {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 1em 2em;
  margin: 0 0 1.5rem;
  padding: 0 2rem 2rem;
  border-radius: 1em;
  background: white;
  overflow: hidden;
}
@media (max-width: 45em) {
  main {
    grid-template-columns: repeat(6, 1fr);
  }
}
main > * {
  grid-column: span 6;
}
main > .full,
main > section,
main > table,
main > ul,
main > h1 {
  grid-column: 1/-1;
}
main h1 {
  margin: 0 -2rem;
  padding: calc(0.4rem + 0.6em) 2rem 0.7em;
  color: white;
  background-color: var(--green);
  color: var(--blueD);
  color: #304107;
  color: #004e00;
  font-family: Fredoka;
  font-weight: 500;
  font-size: clamp(1.2em, 5vw, 2em);
  line-height: 1em;
  /* font-stretch: condensed; */
}
main h2 {
  margin: 0 0 0.5em;
  font-family: Fredoka;
  font-weight: 600;
  font-size: 1.4em;
  font-stretch: semi-condensed;
  color: var(--blue);
}
main h3 {
  margin: 0 0 0.6em;
  font-family: Fredoka;
  font-weight: 500;
  font-size: 1.15em;
  font-stretch: condensed;
}
main p {
  max-width: 50em;
  line-height: 1.4em;
}
main a {
  padding: 0 0.1em;
  font-weight: 500;
  color: var(--blue);
  /* text-decoration: underline; */
  /* text-underline-offset: 0.2em; */
  background-image: linear-gradient(to top, transparent 0.1em, var(--blueO) 0.15em, transparent 0.2em);
  white-space: nowrap;
}

main#willkommen {
  grid-auto-flow: dense;
  font-size: 1.1em;
}
main#willkommen > h1 + p {
  grid-column: 1/-1;
}
main#willkommen > div {
  grid-column: 1/7;
}
main#willkommen > img {
  justify-self: center;
  grid-column: -7/-1;
  max-width: min(33em, 100%);
  margin-bottom: 1em;
}
main#willkommen > p:last-child {
  grid-column: 2/-2;
  text-align: center;
}
main#willkommen strong {
  margin: 0.3em;
  font-weight: 700;
  text-align: center;
  white-space: nowrap;
}

main#wir-laden-ein > table {
  display: grid;
  grid-template-columns: auto auto 1fr;
  gap: 1em 1em;
}
main#wir-laden-ein > table tbody {
  display: contents;
}
main#wir-laden-ein > table tr {
  grid-column: 1/-1;
  display: grid;
  grid-template-columns: subgrid;
  row-gap: 1em;
  align-items: start;
  padding: 1em;
  border-radius: 1em;
  border: 0.1em solid #ccc;
}
main#wir-laden-ein > table tr:nth-child(2n+1) {
  background-color: #f3f3f3;
}
main#wir-laden-ein > table td:first-child {
  grid-column: 1/3;
  display: grid;
  grid-template-columns: subgrid;
  white-space: nowrap;
}
main#wir-laden-ein > table td:first-child time > :nth-child(1) {
  grid-row: span 2;
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1;
  padding: 0.4em;
  border-radius: 0.2em;
  font-size: 1.5em;
  font-weight: 600;
  line-height: 1em;
  color: white;
  background: var(--blue);
}
main#wir-laden-ein > table td:first-child time > :nth-child(2) {
  font-weight: 900;
  line-height: 1.4em;
  color: var(--blue);
}
main#wir-laden-ein > table td:first-child time > :nth-child(3) {
  font-weight: 700;
  color: var(--blue);
}
main#wir-laden-ein > table td:last-child {
  margin-left: 3em;
}
@media (max-width: 40em) {
  main#wir-laden-ein > table td:last-child {
    grid-column: 1/-1;
    margin-left: 0;
  }
}
main#wir-laden-ein > table strong {
  margin: 0 0 1em;
  font-family: Fredoka;
  font-size: clamp(1em, 3vw, 1.4em);
  font-weight: 500;
  font-stretch: condensed;
  line-height: 1em;
}
main#wir-laden-ein > table .icons {
  display: flex;
  gap: 0.8em;
  margin: -0.3em 0 -0.5em;
}
main#wir-laden-ein > table .icons img {
  height: 1.4em;
  aspect-ratio: 1;
  filter: opacity(0.6);
}

main#gemeindeleben > ul {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(auto-fit, min(24em, 100%));
  grid-auto-rows: 1fr;
  justify-content: center;
  gap: 2em;
  margin: 0;
  padding: 0;
}
main#gemeindeleben > ul > li {
  flex: 0 0 auto;
  display: grid;
  grid-template-columns: auto;
  grid-template-rows: auto;
  outline: none;
  perspective: 100vw;
  transform-style: preserve-3d;
}
main#gemeindeleben > ul > li > div {
  grid-column: 1;
  grid-row: 1;
  padding: 1em;
  border-radius: 1em;
  border-width: 0.3em;
  border-style: solid;
  background-color: #f3f3f3;
  backface-visibility: hidden;
  transition: transform 0.5s ease-in-out;
}
main#gemeindeleben > ul > li > div:first-child {
  border-color: var(--blueO);
  border-color: var(--blueO) var(--green) var(--green) var(--blueO);
}
main#gemeindeleben > ul > li > div:first-child img {
  width: 100%;
  aspect-ratio: 16/9;
  margin-bottom: 1em;
  border-radius: 0.5em;
  -o-object-fit: cover;
     object-fit: cover;
}
main#gemeindeleben > ul > li > div:first-child p {
  margin-bottom: 0em;
}
main#gemeindeleben > ul > li > div:last-child {
  border-color: var(--green);
  border-color: var(--green) var(--blueO) var(--blueO) var(--green);
  transform: rotateY(180deg);
}
main#gemeindeleben > ul > li:focus > div:first-child, main#gemeindeleben > ul:not(:has(> li:focus)) > li:hover > div:first-child {
  transform: rotateY(180deg);
}
main#gemeindeleben > ul > li:focus > div:last-child, main#gemeindeleben > ul:not(:has(> li:focus)) > li:hover > div:last-child {
  transform: rotateY(360deg);
}
main#gemeindeleben > ul strong {
  display: block;
  margin: 0 0 0.5em;
  font-family: Fredoka;
  font-weight: 600;
  font-size: 1.2em;
  color: var(--blueD);
}

main#aktuelles > section {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1em;
  margin-top: 1em;
}
main#aktuelles > section nav {
  grid-row: span 2;
  margin-bottom: 1em;
  font-size: 0.9em;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
main#aktuelles > section nav h2 {
  font-family: inherit;
  margin: 0 0 0.5em;
  font-size: 1.2em;
  font-weight: 500;
  color: #666;
}
main#aktuelles > section nav ul {
  display: flex;
  flex-direction: column;
  margin: -0.2em -0.5em;
  padding: 0;
  outline: none;
  list-style: none;
}
main#aktuelles > section nav li {
  padding: 0.2em 0.5em;
  border: 0.1em solid transparent;
  border-radius: 0.5em;
}
main#aktuelles > section nav li:has(:focus-visible) {
  border-color: black;
}
main#aktuelles > section nav label {
  position: relative;
  font-weight: 700;
  white-space: nowrap;
  cursor: pointer;
}
main#aktuelles > section nav label:not(:has(input:checked)) span::before {
  content: attr(data-content);
  position: absolute;
  inset: 0;
  font-weight: 400;
  background-color: white;
}
main#aktuelles > section nav input {
  box-sizing: border-box;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  -webkit-clip-path: xywh(0 0 0 0);
          clip-path: xywh(0 0 0 0);
  transform: scale(0);
  overflow: hidden;
}
main#aktuelles > section nav select {
  display: none;
}
main#aktuelles > section article {
  grid-column: -2;
  padding: 1em;
  border-radius: 1em;
  border: 0.1em solid #ccc;
  background-color: #f3f3f3;
  overflow: hidden;
}
main#aktuelles > section article:has(.category) {
  border-top-right-radius: 0;
}
main#aktuelles > section article .category {
  float: right;
  width: 7em;
  margin: -1em -1em 0 1em;
  padding: 0.5em 1em;
  border-bottom-left-radius: 0.5em;
  font-weight: 600;
  font-stretch: expanded;
  color: white;
  text-align: center;
  background: var(--blueO);
}
main#aktuelles > section article details {
  clear: both;
  margin: 1em -1em -1em;
}
main#aktuelles > section article details > summary {
  margin: 0 0.5em 0.5em;
  padding: 0.5em;
  border-radius: 0.5em;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  cursor: pointer;
}
main#aktuelles > section article details > summary::marker {
  margin-right: 2em;
}
main#aktuelles > section article details > section {
  padding: 1em;
  border-top: 0.1em solid #ccc;
  background: white;
}
@media (max-width: 50em) {
  main#aktuelles > section {
    grid-template-columns: 1fr;
  }
  main#aktuelles > section nav ul {
    display: none;
  }
  main#aktuelles > section nav select {
    display: block;
    width: 100%;
    padding: 0.5em;
    border-radius: 0.5em;
  }
}

footer {
  display: grid;
  grid-template-areas: "adresse contact nav";
  grid-template-columns: auto auto 1fr;
  align-items: start;
  gap: 2em 4em;
  margin: auto 1.5rem 2rem;
  font-size: 0.9em;
  white-space: nowrap;
}
footer > * {
  display: flex;
}
footer > .adresse {
  grid-area: adresse;
}
footer > .adresse a span:first-child {
  margin-right: 0.5em;
}
footer > .contact {
  grid-area: contact;
}
footer > ul {
  grid-area: nav;
  gap: 0.4em 2em;
  justify-self: flex-end;
  margin: 0;
  padding: 0;
  list-style: none;
}
footer > ul li {
  display: contents;
}
footer > ul a {
  display: flex;
}
footer a {
  padding: 0 0.5rem;
}
@media (max-width: 75em) {
  footer {
    grid-template-areas: "adresse nav" "contact nav";
    grid-template-columns: auto 1fr;
  }
  footer > * {
    flex-direction: column;
  }
  footer > .adresse a {
    display: grid;
    grid-template-rows: auto auto;
    grid-auto-flow: column;
    justify-content: flex-start;
  }
  footer > .adresse a span:first-child {
    margin-right: 0;
  }
}
@media (max-width: 30em) {
  footer {
    grid-template-areas: "adresse" "contact" "nav";
    grid-template-columns: auto 1fr;
  }
}/*# sourceMappingURL=style.css.map */