@charset "UTF-8";
/*
Theme Name: LDN Flotilla
Version: 1.1.1
*/
@font-face {
  font-family: "Telegraf";
  src: url("fonts/Telegraf-Variable.woff2") format("woff2");
  font-display: swap;
  font-weight: 200 900;
}
:root {
  --color-background: whitesmoke;
  --color-text: #5c5c5c;
  --color-primary: #0d81ce;
  --color-primary-oklch: 0.43 0.132 204.0;
  --color-accent: #9fd8fe;
  --color-accent-oklch: 0.81 0.147 204.0;
  --brand-hue: 204.0;
  --color-highlight: #ddd055;
  --color-white: #ffffff;
  --ldn-brand: #1A3880;
  --ldn-accent: #557DDD;
  --shadow-dark: rgba(227, 227, 227, 0.7);
  --shadow-light: rgba(255, 255, 255, 0.7);
  --shadow-inset: rgba(85, 180, 221, 0.25);
  --radius-small: 0.1666666667rem;
  --radius-medium: 0.5rem;
  --radius-large: 1rem;
  --radius-round: 2em;
  --radius-card: 0.5rem;
  --shadow-size-small: 0.125rem;
  --shadow-size-medium: 0.25rem;
  --shadow-size-large: 0.5rem;
  --shadow-size-xl: 1rem;
  --font-family-primary: "Telegraf", sans-serif;
  --font-family-mono: "Consolas", monospace;
  --transition-standard: all 0.3s cubic-bezier(0.4, 0, 0.6, 1);
  --headerHeight: 107px;
  --footerHeight: 55px;
}

/*
Theme Name: LDN Flotilla
Version: 1.1.1
*/
body {
  font-family: var(--font-family-primary);
  color: var(--color-text);
  background-color: var(--color-background);
  font-variant-ligatures: common-ligatures;
  text-shadow: 0 -1px 1px rgba(255, 255, 255, 0.01);
  font-synthesis: none;
}

.page__outer {
  position: relative;
  background-color: var(--color-background);
  padding: env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
  scroll-snap-align: start;
}

.page__inner {
  background-color: var(--color-background);
  transition: var(--transition-standard);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  position: relative;
  max-inline-size: 980px;
  margin: auto;
  padding-block-start: 0;
  padding-block-end: 1rem;
  padding-inline: 1rem;
}

.page__main {
  position: relative;
  min-block-size: calc(100vh - var(--headerHeight) - var(--footerHeight));
}

.neumorphic-button,
.button,
.wp-block-button__link,
#searchsubmit {
  box-shadow: -8px -8px 16px var(--shadow-dark), 8px 8px 16px var(--shadow-light);
  background-image: linear-gradient(142deg, var(--color-background), var(--color-white) 61.803398875%);
  border-radius: var(--radius-small);
  border: none;
  padding-block: 0.5rem;
  padding-inline: 1rem;
  color: var(--color-primary);
  font-family: var(--font-family-primary);
  transition: var(--transition-standard);
  cursor: pointer;
  user-select: none;
}
.neumorphic-button:hover,
.button:hover,
.wp-block-button__link:hover,
#searchsubmit:hover {
  background-image: linear-gradient(142deg, var(--color-background), var(--color-white) 38.196601125%);
  color: oklch(var(--color-accent-oklch));
  color: var(--color-accent);
}
.neumorphic-button:active,
.button:active,
.wp-block-button__link:active,
#searchsubmit:active {
  box-shadow: inset -8px -8px 16px var(--shadow-light), inset 8px 8px 16px var(--shadow-dark);
}

.neumorphic-card,
.episode,
.sponsor__detail,
.provider .provider__item {
  box-shadow: -10px -10px 20px var(--shadow-dark), 10px 10px 20px var(--shadow-light);
  border-radius: var(--radius-card);
  background-color: var(--color-background);
  padding: 1.5rem;
  transition: var(--transition-standard);
}
.neumorphic-card:hover,
.episode:hover,
.sponsor__detail:hover,
.provider .provider__item:hover {
  box-shadow: -12px -12px 24px var(--shadow-dark), 12px 12px 24px var(--shadow-light);
}

.neumorphic-input,
input[type=text],
input[type=email],
input[type=search],
textarea,
select {
  box-shadow: inset -6px -6px 12px var(--shadow-light), inset 6px 6px 12px var(--shadow-dark);
  border-radius: var(--radius-small);
  border: none;
  background-color: var(--color-background);
  font-family: var(--font-family-primary);
  padding: 0.75rem;
  transition: var(--transition-standard);
}
.neumorphic-input:focus,
input[type=text]:focus,
input[type=email]:focus,
input[type=search]:focus,
textarea:focus,
select:focus {
  box-shadow: inset -6px -6px 12px var(--shadow-light), inset 6px 6px 12px var(--shadow-dark);
  outline: none;
  box-shadow: 0 0 0.25rem 0 oklch(var(--color-accent-oklch)/0.25), var(--shadow-size-small) var(--shadow-size-small) var(--shadow-size-medium) var(--shadow-dark), calc(-1 * var(--shadow-size-small)) calc(-1 * var(--shadow-size-small)) var(--shadow-size-medium) var(--shadow-light);
  box-shadow: 0 0 0.25rem 0 var(--color-accent), var(--shadow-size-small) var(--shadow-size-small) var(--shadow-size-medium) var(--shadow-dark), calc(-1 * var(--shadow-size-small)) calc(-1 * var(--shadow-size-small)) var(--shadow-size-medium) var(--shadow-light);
}

.neumorphic {
  box-shadow: -8px -8px 16px var(--shadow-dark), 8px 8px 16px var(--shadow-light);
  border-radius: var(--radius-medium);
  background-color: var(--color-background);
}

.neumorphic-inset {
  box-shadow: inset -8px -8px 16px var(--shadow-light), inset 8px 8px 16px var(--shadow-dark);
  border-radius: var(--radius-medium);
  background-color: var(--color-background);
  overflow: hidden;
}

@media (inline-size <= 768px) {
  :root {
    --shadow-size-small: 0.1rem;
    --shadow-size-medium: 0.2rem;
    --shadow-size-large: 0.4rem;
    --shadow-size-xl: 0.8rem;
  }
  .neumorphic-card {
    padding: 1rem;
  }
  .page__inner {
    padding-block-start: 0;
    padding-block-end: 0.5rem;
    padding-inline: 0.5rem;
  }
}
button:focus {
  outline: 1px dotted #808080 !important;
}

.podlove-web-player,
div[class*=podlove],
iframe[src*=podlove] {
  --podlove-primary: var(--color-primary);
  --podlove-primary-oklch: var(--color-primary-oklch);
  --podlove-accent: var(--color-accent);
  --podlove-accent-oklch: var(--color-accent-oklch);
}

.podlove-web-player,
div[class*=podlove],
iframe[src*=podlove] {
  --podlove-brand: oklch(var(--color-primary-oklch)) !important;
  --podlove-brand: var(--color-primary) !important; /* Fallback */
  --podlove-brandDark: oklch(var(--color-accent-oklch)) !important;
  --podlove-brandDark: var(--color-accent) !important; /* Fallback */
  --podlove-brandDarkest: oklch(var(--color-primary-oklch)) !important;
  --podlove-brandDarkest: var(--color-primary) !important; /* Fallback */
  --podlove-brandLightest: oklch(var(--color-accent-oklch)) !important;
  --podlove-brandLightest: var(--color-accent) !important; /* Fallback */
  background-color: var(--color-background) !important;
  background: var(--color-background) !important;
}

.podlove-web-player button,
div[class*=podlove] button,
.podlove-web-player [class*=play],
div[class*=podlove] [class*=play] {
  background-color: oklch(var(--color-primary-oklch)) !important;
  background-color: var(--color-primary) !important; /* Fallback */
  color: var(--color-background) !important;
}

.podlove-web-player [class*=progress],
div[class*=podlove] [class*=progress],
.podlove-web-player [class*=slider],
div[class*=podlove] [class*=slider] {
  background-color: oklch(var(--color-primary-oklch)) !important;
  background-color: var(--color-primary) !important; /* Fallback */
}

iframe[src*=podlove] {
  border: 2px solid oklch(var(--color-primary-oklch)/0.3) !important;
  border: 2px solid var(--color-primary) !important;
  border-radius: var(--radius-medium);
}

[class*=teaser--], .teaser {
  box-shadow: -8px -8px 16px var(--shadow-dark), 8px 8px 16px var(--shadow-light) !important;
  border-radius: var(--radius-medium);
  background-color: var(--color-background);
  padding: 1.25rem;
  margin-block: 2rem;
  transition: var(--transition-standard);
}
[class*=teaser--]:hover, .teaser:hover {
  box-shadow: -10px -10px 20px var(--shadow-dark), 10px 10px 20px var(--shadow-light) !important;
}

.teaser__summary {
  margin-block-start: 0;
  font-size: 1em;
  line-height: 1.4;
  color: var(--color-text-muted);
}
.teaser__summary .teaser__summary-text {
  font-size: 1em;
  line-height: 1.4;
  color: var(--color-text-muted);
}

.teaser__content {
  padding-inline: 1.5rem;
}

.teaser--episode .teaser__meta-line {
  font-size: 1em;
  color: var(--color-text-muted);
  margin-block-end: 0.75rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.4rem;
  line-height: 1.4;
}
.teaser--episode .teaser__title-link {
  font-size: 1em;
  font-weight: 500;
  color: var(--color-primary);
  text-decoration: none;
}
.teaser--episode .teaser__title-link:hover {
  color: var(--color-accent);
  text-decoration: underline;
}
.teaser--episode .teaser__separator {
  color: var(--color-text-muted);
  font-weight: normal;
  font-size: 1em;
}
.teaser--episode .teaser__date,
.teaser--episode .teaser__contributors,
.teaser--episode .teaser__tags {
  font-size: 1em;
  color: var(--color-text-muted);
  font-weight: normal;
}
.teaser--episode .teaser__tags a {
  color: var(--color-primary);
  text-decoration: none;
  font-size: 1em;
}
.teaser--episode .teaser__tags a:hover {
  color: var(--color-accent);
  text-decoration: underline;
}

.teaser__subtitle {
  font-size: 1em;
  font-weight: 400;
  font-style: italic;
  color: var(--color-text-muted);
  margin-block-end: 0.75rem;
  line-height: 1.4;
}

html {
  scroll-behavior: smooth;
}

.teaser__player {
  box-shadow: none !important;
  border: none !important;
  background: transparent !important;
}
.teaser__player .podlove-web-player,
.teaser__player div[class*=podlove] {
  box-shadow: none !important;
  border: none !important;
  background: transparent !important;
}

.podlove-web-player [class*=chapter],
div[class*=podlove] [class*=chapter],
.podlove-web-player [class*=chapter] *,
div[class*=podlove] [class*=chapter] * {
  color: var(--color-background) !important;
}

.podlove-web-player button svg,
div[class*=podlove] button svg,
.podlove-web-player [class*=play] svg,
div[class*=podlove] [class*=play] svg {
  fill: var(--color-background) !important;
  color: var(--color-background) !important;
}

[data-test=player--xl] {
  margin-inline: auto;
}

.announcement-wrapper {
  margin-block: 4rem;
}

@media (inline-size <= 768px) {
  .podlove-web-player,
  div[class*=podlove] {
    --podlove-primary: var(--color-primary);
    --podlove-accent: var(--color-accent);
  }
}
@media (prefers-color-scheme: dark) {
  .podlove-web-player,
  div[class*=podlove] {
    --podlove-primary: oklch(var(--color-primary-oklch) / 0.9);
    --podlove-accent: oklch(var(--color-accent-oklch) / 0.9);
  }
}
.a11y, .page__heading,
.skip-link {
  position: absolute !important;
  clip: rect(1px, 1px, 1px, 1px) !important;
  clip-path: inset(50%) !important;
  inline-size: 1px !important;
  block-size: 1px !important;
  overflow: hidden !important;
  padding: 0 !important;
  border: 0 !important;
  white-space: nowrap !important;
}
.a11y:focus, .page__heading:focus,
.skip-link:focus {
  position: absolute !important;
  inset-block-start: 1rem !important;
  inset-inline-start: 1rem !important;
  clip: auto !important;
  clip-path: none !important;
  inline-size: auto !important;
  block-size: auto !important;
  padding-block: 0.5rem !important;
  padding-inline: 1rem !important;
  background-color: var(--color-background) !important;
  color: var(--color-text) !important;
  text-decoration: underline !important;
  z-index: 9999 !important;
  border: 2px solid var(--color-primary) !important;
  border-radius: var(--radius-small) !important;
}

.page__header {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  margin-block-start: 1rem;
  padding-block: 1rem;
  padding-inline: 2rem;
  position: relative;
  margin-block-end: 3rem;
  overflow: hidden;
  gap: 0;
}

.page__branding {
  display: flex;
  align-items: start;
  gap: 0.25rem;
}
.page__branding a {
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.page__brand-wrapper {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
}

.page__brand {
  font-size: 2.5rem;
  font-weight: 467;
  color: var(--color-primary);
  margin: 0;
  line-height: 1.2;
}

.page__tagline {
  font-size: 0.9rem;
  font-weight: 400;
  color: var(--color-text-muted);
  margin: 0;
  line-height: 1.3;
  max-width: 300px;
}

.page__logo {
  margin: 0;
  display: flex;
  align-items: center;
  flex-shrink: 0;
  padding-block-start: 0.5rem;
}
.page__logo img {
  inline-size: auto;
  block-size: 5rem;
  object-fit: contain;
  object-position: center;
}

.page__header-image-wrapper {
  position: relative;
  margin: -2rem -2rem 2rem;
}
@media (max-width: 768px) {
  .page__header-image-wrapper {
    margin: -1rem -1rem 1rem;
  }
}
.page__header-image-wrapper:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 4rem;
  background: linear-gradient(to top, var(--color-background), transparent);
  z-index: 1;
  pointer-events: none;
}

.page__header-image {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  aspect-ratio: 6.2/1;
}
@media (max-width: 768px) {
  .page__header-image {
    aspect-ratio: 3.2/1;
  }
}

.page__network {
  position: absolute;
  bottom: 1rem;
  right: 1rem;
  font-size: 0.8em;
  line-height: 1;
  text-transform: uppercase;
  color: var(--color-text);
  letter-spacing: 0.0618lh;
}
.page__network--overlay {
  position: absolute;
  inset: 2rem auto auto 2rem;
  padding: 0.5rem 1rem;
  color: var(--color-text);
  z-index: 10;
  min-width: 6rem;
}
@media (max-width: 768px) {
  .page__network--overlay {
    top: 0.5rem;
    left: 0.5rem;
    width: auto;
    max-width: calc(100% - 1rem);
    min-width: auto;
    font-size: 0.85rem;
    padding: 0.4rem 0.75rem;
  }
}
.page__network--light {
  color: #ffffff;
}
.page__network::before {
  content: url('data:image/svg+xml;utf8,<svg viewBox="0 0 40 25" xmlns="http://www.w3.org/2000/svg"><path d="M39.4197 9.71678H33.7603L32.0237 4.05277H28.897C27.7756 2.82018 26.4101 1.83562 24.8879 1.16197C23.3656 0.488316 21.7199 0.140381 20.056 0.140381C18.3921 0.140381 16.7465 0.488316 15.2242 1.16197C13.7019 1.83562 12.3365 2.82018 11.2151 4.05277H8.08839L6.35172 9.71678H0.692383L3.54068 18.8848H10.1565C11.254 20.5039 12.7298 21.8293 14.4553 22.7454C16.1808 23.6615 18.1036 24.1404 20.056 24.1404C22.0085 24.1404 23.9312 23.6615 25.6568 22.7454C27.3823 21.8293 28.8581 20.5039 29.9555 18.8848H36.5714L39.4197 9.71678Z" fill="%235c5c5c"/></svg>');
  display: inline-block;
  block-size: 1.5lh;
  inline-size: 2.427lh;
  margin-right: 0.382lh;
  vertical-align: middle;
  translate: 0 -0.1lh;
}
.page__network--light::before {
  content: url('data:image/svg+xml;utf8,<svg viewBox="0 0 40 25" xmlns="http://www.w3.org/2000/svg"><path d="M39.4197 9.71678H33.7603L32.0237 4.05277H28.897C27.7756 2.82018 26.4101 1.83562 24.8879 1.16197C23.3656 0.488316 21.7199 0.140381 20.056 0.140381C18.3921 0.140381 16.7465 0.488316 15.2242 1.16197C13.7019 1.83562 12.3365 2.82018 11.2151 4.05277H8.08839L6.35172 9.71678H0.692383L3.54068 18.8848H10.1565C11.254 20.5039 12.7298 21.8293 14.4553 22.7454C16.1808 23.6615 18.1036 24.1404 20.056 24.1404C22.0085 24.1404 23.9312 23.6615 25.6568 22.7454C27.3823 21.8293 28.8581 20.5039 29.9555 18.8848H36.5714L39.4197 9.71678Z" fill="%23ffffff"/></svg>');
}
.page__network b {
  font-weight: 700;
}

.menu-container {
  position: fixed;
  inset: 2rem 0 auto;
  z-index: 999;
  inline-size: calc(100dvi - 4rem);
  max-inline-size: calc(980px - 2rem);
  margin: auto;
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
  pointer-events: none;
}
.menu-container * {
  pointer-events: all;
}

.menu-toggle {
  inline-size: 4.045rem;
  block-size: 2.5rem;
  background-color: whitesmoke;
  border: none;
  border-radius: var(--radius-small);
  cursor: pointer;
  position: relative;
  inset-inline-end: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--transition-standard);
}
.menu-toggle:hover .menu-toggle__line {
  background-color: var(--color-primary);
}
.menu-toggle:focus {
  outline: none;
}

.menu-toggle__icon {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  inline-size: 1.25rem;
  block-size: 1rem;
  justify-content: center;
  align-items: center;
}

.menu-toggle__line {
  display: block;
  inline-size: 100%;
  block-size: 2px;
  background-color: var(--color-primary);
  border-radius: 1px;
  transition: var(--transition-standard);
  transform-origin: center;
}

.page__menu {
  margin: 0;
  padding: 0;
  border: none;
  background: none;
  max-inline-size: none;
  max-block-size: none;
}
.page__menu[open] {
  display: flex;
  position: fixed;
  inset-block: 1rem auto;
  inset-inline: 0;
  block-size: fit-content;
  max-block-size: 100vh;
  margin: 0 auto;
  padding: 0;
  transform: none;
  animation: fadeIn 0.3s ease-out;
  z-index: 1001;
  pointer-events: auto;
  inline-size: calc(100dvi - 2rem);
  max-inline-size: 980px;
}

.page__menu::backdrop {
  background-color: rgba(0, 0, 0, 0.1);
  animation: fadeIn 0.3s ease-out;
}

.menu__content {
  inline-size: auto;
  block-size: auto;
  background-color: var(--color-primary);
  border-radius: var(--radius-medium);
  color: var(--color-background);
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  margin: 0 0 0 auto;
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.menu-close {
  position: absolute;
  inset-block-start: 1rem;
  inset-inline: auto 1rem;
  inline-size: 4.045rem;
  block-size: 2.5rem;
  background-color: var(--color-background);
  border: none;
  border-radius: var(--radius-small);
  cursor: pointer;
  z-index: 1002;
  transition: var(--transition-standard);
}
.menu-close .menu-close__icon {
  display: block;
  inline-size: 1.25rem;
  block-size: 1.25rem;
  position: relative;
  margin: auto;
}
.menu-close .menu-close__icon::before, .menu-close .menu-close__icon::after {
  content: "";
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: 0;
  inline-size: 100%;
  block-size: 2px;
  background-color: var(--color-text);
  transition: var(--transition-standard);
}
.menu-close .menu-close__icon::before {
  transform: translateY(-50%) rotate(45deg);
}
.menu-close .menu-close__icon::after {
  transform: translateY(-50%) rotate(-45deg);
}
.menu-close:hover .menu-close__icon::before, .menu-close:hover .menu-close__icon::after {
  background-color: var(--color-primary);
}

.menu__list {
  list-style: none;
  margin: 0;
  padding-block-start: 4.5rem;
  padding-block-end: 0.5rem;
  padding-inline: 0.5rem;
  display: flex;
  flex-direction: column;
}
.menu__list li {
  margin: 0;
}
.menu__list li a {
  display: block;
  padding-block: 1.25rem;
  padding-inline: 2rem;
  color: var(--color-background);
  text-decoration: none;
  font-size: 1.125rem;
  font-weight: 400;
  border-block-end: 1px solid rgba(255, 255, 255, 0.1);
  transition: var(--transition-standard);
  text-align: left;
}
.menu__list li a:hover {
  background-color: rgba(255, 255, 255, 0.1);
  color: var(--color-background);
}
.menu__list li a:focus {
  outline: none;
}
.menu__list li a.current-menu-item, .menu__list li a.menu__link--current {
  font-weight: 700;
  color: var(--color-background);
}
.menu__list li:last-child a {
  border-block-end: none;
}

.menu-overlay {
  display: none;
}

#wpadminbar {
  z-index: 99 !important;
}

.page-footer .menu__list {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 1.5rem;
  color: var(--color-text);
}
.page-footer .menu__list a {
  color: var(--color-primary);
}
.page-footer .menu__list a:hover {
  color: var(--color-accent);
}

@media (max-width: 768px) {
  .page__header {
    padding: 1rem;
  }
  .page__menu {
    inline-size: 280px;
  }
  .menu__list li a {
    padding-block: 0.875rem;
    padding-inline: 1.5rem;
    font-size: 1rem;
  }
}
@media (max-width: 480px) {
  .page__header {
    flex-direction: column;
    gap: 0.5rem;
    align-items: stretch;
  }
  .page__menu {
    inline-size: 100%;
    inset-inline-end: -100%;
  }
  #menu-toggle-checkbox:checked + .page__header .page__menu {
    inset-inline-end: 0;
    inset-inline-start: 0;
  }
  .menu__list li a {
    padding: 1rem;
    text-align: left;
  }
}
.listing__pagination {
  margin-block-start: 2rem;
  margin-block-end: 1rem;
  text-align: center;
}
.listing__pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-inline-size: 2.5rem;
  block-size: 2.5rem;
  margin-inline: 0.25rem;
  padding-inline: 0.75rem;
  padding-block: 0.5rem;
  text-decoration: none;
  font-weight: 500;
  border-radius: var(--radius-small);
  transition: var(--transition-standard);
  background-color: var(--color-background);
  color: var(--color-text);
  box-shadow: -4px -4px 8px var(--shadow-light), 4px 4px 8px var(--shadow-dark);
}
.listing__pagination .page-numbers:hover {
  color: var(--color-primary);
  box-shadow: -6px -6px 12px var(--shadow-light), 6px 6px 12px var(--shadow-dark);
  transform: translateY(-1px);
}
.listing__pagination .page-numbers:focus {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.listing__pagination .page-numbers.current {
  background-color: var(--color-primary);
  color: var(--color-background);
  box-shadow: inset -2px -2px 4px rgba(255, 255, 255, 0.1), inset 2px 2px 4px rgba(0, 0, 0, 0.2);
}
.listing__pagination .page-numbers.current:hover {
  transform: none;
  box-shadow: inset -2px -2px 4px rgba(255, 255, 255, 0.1), inset 2px 2px 4px rgba(0, 0, 0, 0.2);
}
.listing__pagination .page-numbers.prev, .listing__pagination .page-numbers.next {
  font-weight: 600;
  padding-inline: 1rem;
}
.listing__pagination .page-numbers.dots {
  background: none;
  box-shadow: none;
  color: var(--color-text-muted);
  cursor: default;
}
.listing__pagination .page-numbers.dots:hover {
  background: none;
  box-shadow: none;
  transform: none;
  color: var(--color-text-muted);
}

@media (max-inline-size: 768px) {
  .listing__pagination .page-numbers {
    min-inline-size: 2.25rem;
    block-size: 2.25rem;
    margin-inline: 0.125rem;
    padding-inline: 0.5rem;
    font-size: 0.875rem;
  }
  .listing__pagination .page-numbers.prev, .listing__pagination .page-numbers.next {
    padding-inline: 0.75rem;
  }
}
@media (max-inline-size: 480px) {
  .listing__pagination .page-numbers {
    min-inline-size: 2rem;
    block-size: 2rem;
    font-size: 0.8rem;
  }
  .listing__pagination .page-numbers.prev, .listing__pagination .page-numbers.next {
    padding-inline: 0.5rem;
  }
}
.post-navigation {
  margin: 3rem 0;
}
.post-navigation .nav-links {
  display: flex;
  gap: 2rem;
}
.post-navigation .nav-links > * {
  flex: 1;
}
.post-navigation .nav-previous,
.post-navigation .nav-next {
  display: block;
  text-decoration: none;
  color: inherit;
  background: var(--color-background);
  border-radius: 1rem;
  padding: 1.5rem;
  box-shadow: 8px 8px 16px rgba(0, 0, 0, 0.1), -8px -8px 16px rgba(255, 255, 255, 0.8), inset 0 0 0 1px rgba(255, 255, 255, 0.2);
  transition: all 0.2s ease;
}
.post-navigation .nav-previous:hover, .post-navigation .nav-previous:focus,
.post-navigation .nav-next:hover,
.post-navigation .nav-next:focus {
  transform: translateY(-2px);
  box-shadow: 10px 10px 20px rgba(0, 0, 0, 0.15), -10px -10px 20px rgba(255, 255, 255, 0.9), inset 0 0 0 1px rgba(255, 255, 255, 0.3);
}
.post-navigation .nav-previous:focus,
.post-navigation .nav-next:focus {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.post-navigation .nav-previous {
  text-align: left;
}
.post-navigation .nav-next {
  text-align: right;
}
.post-navigation .nav-subtitle {
  display: block;
  font-size: 0.8rem;
  color: var(--color-text-muted);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 0.5rem;
}
.post-navigation .nav-title {
  display: block;
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-text);
  line-height: 1.3;
}

@media (max-width: 768px) {
  .post-navigation {
    margin: 2rem 0;
  }
  .post-navigation .nav-links {
    flex-direction: column;
    gap: 1rem;
  }
  .post-navigation .nav-previous,
  .post-navigation .nav-next {
    padding: 1rem;
    text-align: center;
  }
  .post-navigation .nav-title {
    font-size: 0.9rem;
  }
}
/**
 * Neumorphic Separator Styles
 * Creates a groove/inline effect for hr elements
 */
hr,
.wp-block-separator {
  border: none;
  height: 1px;
  margin-block: 2rem;
  background: transparent;
  border-top: 1px solid var(--shadow-dark);
  border-bottom: 1px solid var(--shadow-light);
}

/* ==========================================================================
   Scrollbox Component - Unified horizontal scrolling for blocks
   ========================================================================== */
/**
 * Base Scrollbox Wrapper - Neumorphic container
 */
.scrollbox-wrapper {
  margin: 2rem 0;
  box-shadow: -8px -8px 16px var(--shadow-dark), 8px 8px 16px var(--shadow-light);
  border-radius: var(--radius-medium);
  background-color: var(--color-background);
  padding: 1.5rem;
  /* Android overflow fix */
  overflow: hidden;
  position: relative;
  width: 100%;
  max-width: 100%;
}

/**
 * Scrollbox List - Horizontal scrolling container
 */
.scrollbox {
  display: flex;
  width: auto;
  max-width: 100%;
  list-style: none;
  margin: 0 auto;
  padding: 0;
  gap: 1rem;
  justify-content: center;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-behavior: smooth;
  flex-wrap: nowrap;
  -webkit-overflow-scrolling: touch;
  /* Android fix: Ensure container constraints */
  contain: layout style;
  min-width: 0;
}
.scrollbox:empty {
  display: none;
}
.scrollbox::-webkit-scrollbar {
  height: 1px;
}
.scrollbox::-webkit-scrollbar-thumb {
  background: var(--color-primary);
  border-radius: 4px;
}
.scrollbox::-webkit-scrollbar-track {
  background-color: transparent;
  border-radius: 4px;
}

/**
 * Scrollbox Items - Individual items in the scrollbox
 */
.scrollbox__item {
  flex: 0 0 18%;
  min-width: 0; /* Critical for Android Chrome */
  max-width: 18%; /* Enforce maximum width */
  overflow: hidden; /* Use hidden instead of clip for better support */
  box-sizing: border-box;
}

/**
 * Scrollbox Content - Content wrapper for each item
 */
.scrollbox__content {
  height: 100%;
  width: 100%;
  max-width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  overflow: hidden;
  box-sizing: border-box;
  /* Android Chrome specific fixes */
  min-width: 0;
  word-wrap: break-word;
}

/**
 * Scrollbox Link - Make items clickable
 */
.scrollbox__link {
  display: block;
  text-decoration: none;
  color: inherit;
  height: 100%;
}

/**
 * Scrollbox Image - Image styling for items
 */
.scrollbox__image {
  width: 100%;
  max-width: 100%;
  height: 120px;
  object-fit: cover;
  object-position: center;
  display: block;
  box-sizing: border-box;
  border-radius: 50%;
  /* Android Chrome overflow fix */
  flex-shrink: 0;
}
@media (max-width: 768px) {
  .scrollbox__image {
    height: 100px;
  }
}

/**
 * Scrollbox Info - Text content area
 */
.scrollbox__info {
  padding: 1rem 0.5rem 0;
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-center;
  align-items: center;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  overflow: hidden;
}

/**
 * Scrollbox Title - Main title/name
 */
.scrollbox__title {
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: 0.5rem;
  line-height: 1.3;
  width: 100%;
  max-width: 100%;
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
  text-align: center;
}
@media (max-width: 768px) {
  .scrollbox__title {
    font-size: 0.9rem;
  }
}

/**
 * Scrollbox Subtitle - Secondary info (role, date, etc.)
 */
.scrollbox__subtitle {
  font-size: 0.8rem;
  color: var(--color-primary);
  font-weight: 500;
  margin-bottom: 0.25rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  text-align: center;
  width: 100%;
  max-width: 100%;
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
}
@media (max-width: 768px) {
  .scrollbox__subtitle {
    font-size: 0.75rem;
  }
}

/**
 * Scrollbox Meta - Additional info (company, excerpt, etc.)
 */
.scrollbox__meta {
  font-size: 0.8rem;
  color: var(--color-text-muted);
  text-align: center;
  line-height: 1.4;
  width: 100%;
  max-width: 100%;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
@media (max-width: 768px) {
  .scrollbox__meta {
    font-size: 0.75rem;
    -webkit-line-clamp: 1;
  }
}

/**
 * Scrollbox Bio - Longer text content
 */
.scrollbox__bio {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  line-height: 1.4;
  text-align: center;
  margin-top: 0.5rem;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/**
 * Empty State
 */
.scrollbox-empty {
  text-align: center;
  padding: 2rem;
  color: var(--color-text-muted);
}
.scrollbox-empty h3 {
  color: var(--color-primary);
  margin-bottom: 0.5rem;
}

/**
 * Responsive Adjustments
 */
@media (max-width: 480px) {
  .scrollbox-wrapper {
    padding: 1rem;
    margin: 1.5rem 0;
  }
  .scrollbox {
    gap: 0.75rem;
  }
  .scrollbox__item {
    flex: 0 0 160px;
    min-width: 160px;
    max-width: 160px;
  }
  .scrollbox__image {
    height: 80px;
  }
  .scrollbox__info {
    padding: 0.75rem 0.25rem 0;
  }
}
/* ==========================================================================
   Person Post-Type Styles
   ========================================================================== */
/**
 * Person Grid (Archive)
 */
.person-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 1rem;
  margin-block: 2rem;
}
@media (max-width: 768px) {
  .person-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
}

/**
 * Person Card
 */
.person-card-link {
  display: block;
  text-decoration: none;
  color: inherit;
  height: 100%;
}
.person-card-link:focus {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
  border-radius: 1rem;
}

.person-card-inner {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.person-card-image {
  position: relative;
  overflow: hidden;
}
.person-card-image .person-photo {
  width: 100%;
  height: 250px;
  object-fit: cover;
  object-position: center top;
  display: block;
}

.person-card-content {
  padding: 1.5rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.person-card-header {
  margin-bottom: 1rem;
}

.person-card-name {
  font-size: 1.25rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
  line-height: 1.3;
  color: var(--color-text);
}

.person-card-role {
  color: var(--color-primary);
  font-weight: 600;
  font-size: 0.9rem;
  margin-bottom: 0.25rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.person-card-company {
  color: var(--color-text-muted);
  font-size: 0.9rem;
}

.person-card-bio,
.person-card-excerpt {
  flex: 1;
  margin-bottom: 1rem;
  color: var(--color-text-muted);
  line-height: 1.6;
  font-size: 0.9rem;
}

/**
 * Single Person Page
 */
.person-single {
  max-width: 62ch;
  margin-inline: auto;
}
.person-single .person-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 2rem;
  margin-bottom: 3rem;
}
.person-single .person-image .person-photo {
  border-radius: 0;
  overflow: hidden;
  border: 1px solid var(--color-border, #e0e0e0);
}
.person-single .person-image .person-photo img {
  width: 100%;
  height: auto;
  display: block;
}
.person-single .person-name {
  font-size: 2.5rem;
  font-weight: 800;
  margin-bottom: 0.5rem;
  line-height: 1.2;
  color: var(--color-text);
}
@media (max-width: 768px) {
  .person-single .person-name {
    font-size: 2rem;
  }
}
.person-single .person-role {
  color: var(--color-primary);
  font-size: 1.1rem;
  font-weight: 600;
  margin-bottom: 1rem;
  text-transform: uppercase;
  letter-spacing: 1px;
}
.person-single .person-company {
  color: var(--color-text-muted);
  font-size: 1rem;
  margin-bottom: 0.5rem;
}
.person-single .person-company a {
  color: var(--color-text);
  text-decoration: none;
  font-weight: 500;
}
.person-single .person-company a:hover, .person-single .person-company a:focus {
  color: var(--color-primary);
  text-decoration: underline;
}
.person-single .person-job {
  color: var(--color-text-muted);
  font-size: 1rem;
}
.person-single .person-links {
  margin-top: 1.5rem;
}
.person-single .person-links .person-website {
  display: inline-flex;
  align-items: center;
  padding: 0.75rem 1.5rem;
  background: var(--color-primary);
  color: white;
  text-decoration: none;
  border-radius: 0;
  font-weight: 600;
  transition: all 0.2s ease;
}
.person-single .person-links .person-website:hover, .person-single .person-links .person-website:focus {
  background: var(--color-accent);
}
.person-single .person-content {
  margin-bottom: 3rem;
}
.person-single .person-bio {
  background: var(--color-background-alt);
  padding: 2rem;
  border-radius: 0;
  margin-bottom: 2rem;
}
.person-single .person-bio h2 {
  color: var(--color-primary);
  font-size: 1.5rem;
  margin-bottom: 1rem;
}
.person-single .person-bio .person-bio-content {
  line-height: 1.7;
  color: var(--color-text);
}
.person-single .person-bio .person-bio-content p {
  margin-bottom: 1rem;
}
.person-single .person-bio .person-bio-content p:last-child {
  margin-bottom: 0;
}
.person-single .person-description {
  line-height: 1.7;
  color: var(--color-text);
}
.person-single .person-description h2, .person-single .person-description h3, .person-single .person-description h4 {
  color: var(--color-primary);
  margin-top: 2rem;
  margin-bottom: 1rem;
}
.person-single .person-description p {
  margin-bottom: 1rem;
}
.person-single .person-episodes {
  background: var(--color-background);
  padding: 2rem;
  border-radius: 1rem;
  box-shadow: 8px 8px 16px rgba(0, 0, 0, 0.1), -8px -8px 16px rgba(255, 255, 255, 0.8);
}
.person-single .person-episodes h2 {
  color: var(--color-primary);
  font-size: 1.5rem;
  margin-bottom: 1.5rem;
}
.person-single .person-episodes .episode-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.person-single .person-episodes .episode-teaser {
  padding: 1rem;
  background: var(--color-background-alt);
  border-radius: 0.5rem;
  border-left: 4px solid var(--color-primary);
}
.person-single .person-episodes .episode-teaser h3 {
  font-size: 1.1rem;
  margin-bottom: 0.5rem;
}
.person-single .person-episodes .episode-teaser h3 a {
  color: var(--color-text);
  text-decoration: none;
}
.person-single .person-episodes .episode-teaser h3 a:hover, .person-single .person-episodes .episode-teaser h3 a:focus {
  color: var(--color-primary);
}
.person-single .person-episodes .episode-teaser p {
  color: var(--color-text-muted);
  font-size: 0.9rem;
  line-height: 1.5;
  margin: 0;
}

/**
 * Archive Header
 */
.post-type-archive-person .page-header {
  text-align: center;
  margin-bottom: 3rem;
}
.post-type-archive-person .page-header .page-title {
  font-size: 2.5rem;
  color: var(--color-primary);
  margin-bottom: 1rem;
}
.post-type-archive-person .page-header .archive-description {
  color: var(--color-text-muted);
  font-size: 1.1rem;
  line-height: 1.6;
  max-width: 600px;
  margin: 0 auto;
}
.post-type-archive-person .no-results {
  text-align: center;
  padding: 3rem;
}
.post-type-archive-person .no-results h2 {
  color: var(--color-primary);
  margin-bottom: 1rem;
}
.post-type-archive-person .no-results p {
  color: var(--color-text-muted);
}

/**
 * Responsive Adjustments
 */
@media (max-width: 480px) {
  .person-card-content {
    padding: 1rem;
  }
  .person-card-links {
    flex-direction: column;
    gap: 0.5rem;
  }
  .person-card-links a {
    text-align: center;
  }
  .person-single .person-bio,
  .person-single .person-episodes {
    padding: 1.5rem;
  }
  .person-single .person-name {
    font-size: 1.75rem;
  }
}
.listing__list {
  list-style: none;
  padding-left: 0;
}

p {
  max-inline-size: 62ch;
}

html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
  font-family: var(--font-family-primary);
  color: var(--color-text);
  background-color: var(--color-background);
  font-variant-ligatures: common-ligatures;
  text-shadow: 0 -1px 1px rgba(255, 255, 255, 0.01);
  font-synthesis: none;
  line-height: 1.4;
  -webkit-hyphens: auto;
  hyphens: auto;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-family-primary);
  color: oklch(var(--color-primary-oklch));
  color: var(--color-primary); /* Fallback für ältere Browser */
  margin: 0 0 1rem 0;
  line-height: 1.2;
}

h1 {
  font-size: 2.5rem;
  font-weight: 256;
}

h2 {
  font-size: 2rem;
  font-weight: 467;
}

h3 {
  font-size: 1.5rem;
  font-weight: 467;
}

p {
  margin: 0 0 1rem 0;
  line-height: 1.6;
}

a {
  color: oklch(var(--color-primary-oklch));
  color: var(--color-primary); /* Fallback für ältere Browser */
  text-decoration: none;
  transition: var(--transition-standard);
}
a:hover {
  color: oklch(var(--color-accent-oklch));
  color: var(--color-accent); /* Fallback für ältere Browser */
}

.main-navigation {
  box-shadow: -8px -8px 16px var(--shadow-dark), 8px 8px 16px var(--shadow-light);
  border-radius: var(--radius-medium);
  background-color: var(--color-background);
  padding: 1rem;
  margin-bottom: 2rem;
}
.main-navigation ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}
.main-navigation li {
  margin: 0;
}
.main-navigation a {
  background-image: linear-gradient(142deg, var(--color-background), var(--color-white) 61.803398875%);
  border-radius: var(--radius-small);
  padding: 0.5rem 1rem;
  display: block;
  transition: var(--transition-standard);
}
.main-navigation a:hover {
  background-image: linear-gradient(142deg, var(--color-background), var(--color-white) 38.196601125%);
  color: var(--color-accent);
}

.entry-content {
  box-shadow: -10px -10px 20px var(--shadow-dark), 10px 10px 20px var(--shadow-light);
  border-radius: var(--radius-card);
  background-color: var(--color-background);
  padding: 2rem;
  margin-bottom: 2rem;
}

.entry-title {
  color: var(--color-primary);
  font-size: 2rem;
  margin-bottom: 1rem;
}

.entry-meta {
  color: var(--color-text);
  font-size: 0.875rem;
  margin-bottom: 1.5rem;
  opacity: 0.8;
}

.widget {
  box-shadow: -8px -8px 16px var(--shadow-dark), 8px 8px 16px var(--shadow-light);
  border-radius: var(--radius-medium);
  background-color: var(--color-background);
  padding: 1.5rem;
  margin-bottom: 2rem;
}
.widget .widget-title {
  color: var(--color-primary);
  font-size: 1.25rem;
  margin-bottom: 1rem;
  font-weight: 467;
}

.search-form {
  display: flex;
  gap: 0.5rem;
}
.search-form .search-field {
  box-shadow: inset -6px -6px 12px var(--shadow-light), inset 6px 6px 12px var(--shadow-dark);
  border-radius: var(--radius-small);
  border: none;
  background-color: var(--color-background);
  padding: 0.75rem;
  flex: 1;
  font-family: var(--font-family-primary);
}
.search-form .search-field:focus {
  outline: none;
  box-shadow: 0 0 0.25rem 0 var(--shadow-inset), var(--shadow-size-small) var(--shadow-size-small) var(--shadow-size-medium) var(--shadow-dark), calc(-1 * var(--shadow-size-small)) calc(-1 * var(--shadow-size-small)) var(--shadow-size-medium) var(--shadow-light);
}
.search-form .search-submit {
  box-shadow: -8px -8px 16px var(--shadow-dark), 8px 8px 16px var(--shadow-light);
  background-image: linear-gradient(142deg, var(--color-background), var(--color-white) 61.803398875%);
  border-radius: var(--radius-small);
  border: none;
  padding: 0.75rem 1.5rem;
  color: var(--color-primary);
  font-family: var(--font-family-primary);
  cursor: pointer;
  transition: var(--transition-standard);
}
.search-form .search-submit:hover {
  background-image: linear-gradient(142deg, var(--color-background), var(--color-white) 38.196601125%);
  color: var(--color-accent);
}

.episode {
  box-shadow: -10px -10px 20px var(--shadow-dark), 10px 10px 20px var(--shadow-light);
  border-radius: var(--radius-card);
  background-color: var(--color-background);
  padding: 2rem;
  margin-bottom: 2rem;
  transition: var(--transition-standard);
}
.episode .episode-title {
  color: var(--color-primary);
  font-size: 1.5rem;
  margin-bottom: 1rem;
  font-weight: 421;
}
.episode .episode-meta {
  color: var(--color-text);
  font-size: 0.875rem;
  margin-bottom: 1rem;
  opacity: 0.8;
}
.episode .episode-description {
  line-height: 1.6;
  margin-bottom: 1.5rem;
}
.episode .episode-player {
  box-shadow: inset -8px -8px 16px var(--shadow-light), inset 8px 8px 16px var(--shadow-dark);
  border-radius: var(--radius-medium);
  background-color: var(--color-background);
  padding: 1rem;
  margin-bottom: 1rem;
}

@media (max-width: 768px) {
  .site-header,
  .site-footer {
    padding: 1rem;
  }
  .main-navigation ul {
    flex-direction: column;
  }
  .entry-content,
  .episode {
    padding: 1.5rem;
  }
  .search-form {
    flex-direction: column;
  }
}
@media (max-width: 480px) {
  .entry-content,
  .episode {
    padding: 1rem;
  }
  h1 {
    font-size: 2rem;
  }
  h2 {
    font-size: 1.5rem;
  }
}
.home .page__heading,
.front-page .page__heading {
  display: none;
}
