/**
 * Tellr.in Main Styles
 * Component styles consuming tokens from tokens.css
 */

/* ── Reset & Base ──────────────────────────────────────────────────────────── */

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

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
  font-family: var(--tellr-font-sans);
  font-size: var(--tellr-text-base);
  font-weight: var(--tellr-font-normal);
  line-height: var(--tellr-leading-normal);
  color: var(--tellr-foreground);
  background-color: var(--tellr-background);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

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

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

a:hover {
  color: var(--tellr-brand);
}

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

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

/* ── Layout ────────────────────────────────────────────────────────────────── */

.tellr-container {
  width: 100%;
  max-width: var(--tellr-container-max);
  margin-inline: auto;
  padding-inline: var(--tellr-space-6);
}

.tellr-container--narrow {
  max-width: var(--tellr-container-md);
}

.tellr-container--content {
  max-width: var(--tellr-content-width);
}

.tellr-container--wide {
  max-width: var(--tellr-container-max);
}

/* ── Content + Sidebar Layout ──────────────────────────────────────────────── */

.tellr-layout {
  display: grid;
  gap: var(--tellr-space-10);
  align-items: start;
}

.tellr-layout--sidebar {
  gap: var(--tellr-space-8);
}

@media (min-width: 1024px) {
  .tellr-layout--sidebar {
    grid-template-columns: minmax(0, var(--tellr-content-width)) var(--tellr-sidebar-width);
    gap: var(--tellr-space-8);
  }

  .tellr-article--single .tellr-layout--sidebar {
    grid-template-columns: minmax(0, 1fr) var(--tellr-sidebar-width);
  }
}

.tellr-layout__main {
  min-width: 0;
  max-width: var(--tellr-content-width);
}

.tellr-article--single .tellr-layout__main {
  max-width: none;
  width: 100%;
}

.tellr-site {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.tellr-site__main {
  flex: 1;
}

/* ── Breadcrumbs (Yoast SEO) ───────────────────────────────────────────────── */

.tellr-breadcrumbs {
  border-bottom: 1px solid var(--tellr-border);
  background: oklch(from var(--tellr-muted) l c h / 55%);
}

.tellr-breadcrumbs__inner {
  padding-block: var(--tellr-space-3);
}

.tellr-breadcrumbs__nav,
.tellr-breadcrumbs__nav > span {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--tellr-space-2);
  margin: 0;
  font-size: var(--tellr-text-sm);
  line-height: var(--tellr-leading-snug);
  color: var(--tellr-muted-foreground);
}

.tellr-breadcrumbs__nav a {
  color: var(--tellr-muted-foreground);
  text-decoration: none;
  transition: color var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-breadcrumbs__nav a:hover {
  color: var(--tellr-brand);
}

.tellr-breadcrumbs__nav .breadcrumb_last,
.tellr-breadcrumbs__nav .breadcrumb_last strong {
  color: var(--tellr-foreground);
  font-weight: var(--tellr-font-medium);
}

/* ── Page Header ───────────────────────────────────────────────────────────── */

.tellr-page-header {
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid var(--tellr-border);
  padding-block: var(--tellr-space-16) var(--tellr-space-12);
}

.tellr-page-header__bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.tellr-page-header__gradient {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 75% 100% at 0% 0%, oklch(0.55 0.2 250 / 28%), transparent 55%),
    radial-gradient(ellipse 70% 90% at 100% 100%, oklch(0.62 0.17 280 / 22%), transparent 50%),
    radial-gradient(ellipse 50% 60% at 50% 100%, oklch(0.58 0.15 200 / 18%), transparent 55%),
    var(--tellr-gradient-hero);
  opacity: 1;
}

.tellr-page-header__mesh {
  position: absolute;
  inset: 0;
  opacity: 0.5;
  background: var(--tellr-gradient-mesh);
}

.tellr-page-header__particles {
  position: absolute;
  inset: 0;
}

.tellr-page-header__particles canvas {
  display: block;
  width: 100%;
  height: 100%;
}

.tellr-orb--page-header.tellr-orb--primary {
  top: -90px;
  right: -40px;
  width: 280px;
  height: 280px;
}

.tellr-orb--page-header.tellr-orb--secondary {
  bottom: -70px;
  left: -40px;
  width: 220px;
  height: 220px;
}

.tellr-page-header__inner {
  position: relative;
  z-index: 1;
}

.tellr-page-header__title {
  margin: 0;
  font-size: clamp(var(--tellr-text-2xl), 4vw, var(--tellr-text-4xl));
  font-weight: var(--tellr-font-bold);
  line-height: var(--tellr-leading-tight);
  letter-spacing: var(--tellr-tracking-tight);
}

.tellr-page-header__desc {
  margin: var(--tellr-space-4) 0 0;
  font-size: var(--tellr-text-base);
  line-height: var(--tellr-leading-relaxed);
  color: var(--tellr-muted-foreground);
}

.tellr-page-header__desc p {
  margin: 0;
}

.tellr-page-header__badges {
  display: flex;
  flex-wrap: wrap;
  gap: var(--tellr-space-2);
  margin-top: var(--tellr-space-6);
}

.tellr-page-header-badge {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  padding: 0.375rem 0.875rem;
  border: 1px solid oklch(from var(--tellr-border) l c h / 80%);
  border-radius: var(--tellr-radius-full);
  background: oklch(from var(--tellr-background) l c h / 55%);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  font-size: var(--tellr-text-sm);
  font-weight: var(--tellr-font-medium);
  line-height: 1.25;
  color: var(--tellr-foreground);
  text-decoration: none;
  white-space: nowrap;
  transition:
    color var(--tellr-duration-fast) var(--tellr-ease-out),
    background var(--tellr-duration-fast) var(--tellr-ease-out),
    border-color var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-page-header-badge:hover,
.tellr-page-header-badge:focus-visible {
  color: var(--tellr-brand);
  border-color: var(--tellr-brand);
  background: var(--tellr-brand-muted);
}

.tellr-section--compact {
  padding-block: var(--tellr-space-12);
}

/* ── Header ────────────────────────────────────────────────────────────────── */

.tellr-header {
  position: sticky;
  top: 0;
  z-index: 100;
  height: var(--tellr-header-height);
  border-bottom: 1px solid var(--tellr-border);
  background: oklch(from var(--tellr-background) l c h / 92%);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  overflow: visible;
}

.tellr-header__inner {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  height: 100%;
  gap: var(--tellr-space-6);
}

.tellr-logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  max-width: 180px;
  align-self: center;
  padding: 0;
  background: transparent;
  border: none;
  box-shadow: none;
}

.tellr-logo::before,
.tellr-logo::after {
  display: none;
}

.tellr-logo:hover {
  box-shadow: none;
  transform: none;
}

.tellr-logo__image,
.tellr-logo img,
.tellr-logo .custom-logo {
  display: block;
  width: auto;
  max-width: 160px;
  max-height: 44px;
  height: auto;
  object-fit: contain;
  filter: var(--tellr-logo-filter);
  transition: filter var(--tellr-duration-fast) var(--tellr-ease-out);
}

.dark .tellr-logo__image,
.dark .tellr-logo img,
.dark .tellr-logo .custom-logo,
[data-theme="dark"] .tellr-logo__image,
[data-theme="dark"] .tellr-logo img,
[data-theme="dark"] .tellr-logo .custom-logo {
  filter: none;
}

.tellr-nav {
  display: none;
}

@media (min-width: 768px) {
  .tellr-nav {
    display: flex;
    align-items: stretch;
    justify-content: center;
    flex: 1;
    min-width: 0;
    height: 100%;
    overflow: visible;
  }
}

.tellr-nav__list {
  display: flex;
  align-items: stretch;
  gap: 0.125rem;
  margin: 0;
  padding: 0;
  list-style: none;
  height: 100%;
}

.tellr-nav__list > .menu-item {
  display: flex;
  align-items: stretch;
  position: relative;
  height: 100%;
}

.tellr-nav__link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0 var(--tellr-space-4);
  border-radius: 0;
  font-size: var(--tellr-text-sm);
  font-weight: var(--tellr-font-medium);
  color: var(--tellr-muted-foreground);
  white-space: nowrap;
  transition: color var(--tellr-duration-fast) var(--tellr-ease-out),
    background var(--tellr-duration-fast) var(--tellr-ease-out),
    border-color var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-nav__list > .menu-item > .tellr-nav__link {
  height: 100%;
  border-bottom: 2px solid transparent;
}

.tellr-nav__list > .menu-item > .tellr-nav__link:hover,
.tellr-nav__list > .menu-item.current-menu-item > .tellr-nav__link,
.tellr-nav__list > .menu-item.current-menu-ancestor > .tellr-nav__link,
.tellr-nav__list > .menu-item.current-menu-parent > .tellr-nav__link {
  color: var(--tellr-foreground);
  background: transparent;
  border-bottom-color: var(--tellr-brand);
}

.tellr-nav__list > .menu-item-has-children > .tellr-nav__link::after {
  content: "";
  width: 0.625rem;
  height: 0.625rem;
  margin-top: 1px;
  background: currentColor;
  opacity: 0.65;
  clip-path: polygon(15% 35%, 50% 70%, 85% 35%, 75% 25%, 50% 50%, 25% 25%);
  transition: transform var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-nav__list > .menu-item-has-children:hover > .tellr-nav__link::after,
.tellr-nav__list > .menu-item-has-children:focus-within > .tellr-nav__link::after {
  transform: rotate(180deg);
}

.tellr-nav__list > .menu-item-has-children::before {
  content: "";
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  height: 0.5rem;
  z-index: 121;
}

.tellr-nav__list > .menu-item-has-children > .sub-menu {
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 120;
  min-width: 240px;
  max-height: min(70vh, 28rem);
  margin: 0;
  padding: var(--tellr-space-2);
  list-style: none;
  overflow-y: auto;
  border: 1px solid var(--tellr-border);
  border-top: none;
  border-radius: 0 0 var(--tellr-radius-lg) var(--tellr-radius-lg);
  background: var(--tellr-popover);
  box-shadow: var(--tellr-shadow-lg);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(0);
  transition: opacity var(--tellr-duration-fast) var(--tellr-ease-out),
    visibility var(--tellr-duration-fast);
}

.tellr-nav__list > .menu-item-has-children:hover > .sub-menu,
.tellr-nav__list > .menu-item-has-children:focus-within > .sub-menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.tellr-nav__list .sub-menu .menu-item {
  position: relative;
}

.tellr-nav__list .sub-menu .sub-menu {
  top: 0;
  left: 100%;
  margin-left: -1px;
  border-top: 1px solid var(--tellr-border);
  border-radius: var(--tellr-radius-lg);
}

.tellr-nav__list .sub-menu .tellr-nav__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: var(--tellr-space-2) var(--tellr-space-3);
  border-radius: var(--tellr-radius-md);
  border-bottom: none;
  height: auto;
  white-space: normal;
}

.tellr-nav__list .sub-menu .tellr-nav__link:hover {
  color: var(--tellr-foreground);
  background: var(--tellr-accent);
  border-bottom-color: transparent;
}

.tellr-nav__list .sub-menu .menu-item-has-children > .tellr-nav__link::after {
  clip-path: polygon(35% 15%, 70% 50%, 35% 85%, 25% 75%, 50% 50%, 25% 25%);
  margin-top: 0;
}

.tellr-header__actions {
  display: flex;
  align-items: center;
  align-self: center;
  gap: var(--tellr-space-2);
  flex-shrink: 0;
}

.tellr-header-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  padding: 0;
  border: 1px solid var(--tellr-border);
  border-radius: var(--tellr-radius-md);
  background: var(--tellr-background);
  color: var(--tellr-foreground);
  cursor: pointer;
  transition: background var(--tellr-duration-fast) var(--tellr-ease-out),
    border-color var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-header-btn:hover {
  background: var(--tellr-accent);
}

.tellr-search-modal {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: max(var(--tellr-space-8), 12vh) var(--tellr-space-4) var(--tellr-space-4);
}

.tellr-search-modal[hidden] {
  display: none;
}

.tellr-search-modal__backdrop {
  position: absolute;
  inset: 0;
  padding: 0;
  border: 0;
  background: oklch(from var(--tellr-foreground) l c h / 50%);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  cursor: pointer;
}

.tellr-search-modal__dialog {
  position: relative;
  z-index: 1;
  width: min(100%, 36rem);
  padding: var(--tellr-space-6);
  border: 1px solid var(--tellr-border);
  border-radius: var(--tellr-radius-xl);
  background: var(--tellr-background);
  box-shadow: var(--tellr-shadow-xl);
  animation: tellr-search-modal-in var(--tellr-duration-normal) var(--tellr-ease-out);
}

@keyframes tellr-search-modal-in {
  from {
    opacity: 0;
    transform: translateY(-0.75rem) scale(0.98);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.tellr-search-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--tellr-space-4);
  margin-bottom: var(--tellr-space-4);
}

.tellr-search-modal__title {
  margin: 0;
  font-size: var(--tellr-text-lg);
  font-weight: var(--tellr-font-semibold);
  line-height: var(--tellr-leading-tight);
}

.tellr-search-form--modal {
  display: flex;
  flex-direction: column;
  gap: var(--tellr-space-3);
  max-width: none;
  width: 100%;
}

.tellr-search-modal__input {
  width: 100%;
}

.tellr-search-modal__submit {
  width: 100%;
}

@media (min-width: 640px) {
  .tellr-search-form--modal {
    flex-direction: row;
    align-items: center;
  }

  .tellr-search-modal__input {
    flex: 1 1 auto;
  }

  .tellr-search-modal__submit {
    width: auto;
    flex-shrink: 0;
  }
}

.tellr-search-toggle[aria-expanded="true"] {
  color: var(--tellr-brand);
  border-color: var(--tellr-brand);
  background: var(--tellr-brand-muted);
}

body.tellr-search-open {
  overflow: hidden;
}

.tellr-mobile-nav__search {
  margin-bottom: var(--tellr-space-4);
  padding-bottom: var(--tellr-space-4);
  border-bottom: 1px solid var(--tellr-border);
}

.tellr-theme-toggle__icon--moon {
  display: none;
}

.dark .tellr-theme-toggle__icon--sun,
[data-theme="dark"] .tellr-theme-toggle__icon--sun {
  display: none;
}

.dark .tellr-theme-toggle__icon--moon,
[data-theme="dark"] .tellr-theme-toggle__icon--moon {
  display: block;
}

.tellr-menu-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
}

@media (min-width: 768px) {
  .tellr-menu-toggle {
    display: none;
  }
}

.tellr-mobile-nav {
  border-top: 1px solid var(--tellr-border);
  background: var(--tellr-background);
  padding-block: var(--tellr-space-4);
}

.tellr-mobile-nav .tellr-nav__list {
  flex-direction: column;
  align-items: stretch;
}

.tellr-mobile-nav .tellr-nav__link {
  display: block;
  padding: var(--tellr-space-3);
  height: auto;
  border-bottom: none;
  white-space: normal;
}

.tellr-mobile-nav .tellr-nav__list > .menu-item-has-children > .tellr-nav__link::after {
  display: none;
}

.tellr-hero__particles canvas {
  display: block;
  width: 100%;
  height: 100%;
}

/* ── Hero ──────────────────────────────────────────────────────────────────── */

.tellr-hero {
  position: relative;
  overflow: hidden;
  padding-block: var(--tellr-space-20) var(--tellr-space-16);
}

.tellr-hero__bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.tellr-hero__gradient {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 70% 80% at 100% 0%, oklch(0.62 0.17 280 / 26%), transparent 55%),
    radial-gradient(ellipse 65% 70% at 0% 100%, oklch(0.55 0.2 250 / 28%), transparent 50%),
    var(--tellr-gradient-hero);
}

.tellr-hero__mesh {
  position: absolute;
  inset: 0;
  opacity: 0.55;
  background: var(--tellr-gradient-mesh);
}

.tellr-hero__particles {
  position: absolute;
  inset: 0;
}

.tellr-hero__content {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  max-width: 42rem;
  margin-inline: auto;
  gap: var(--tellr-space-6);
}

.tellr-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: var(--tellr-space-2);
  padding: var(--tellr-space-1) var(--tellr-space-3) var(--tellr-space-1) var(--tellr-space-1);
  border: 1px solid var(--tellr-border);
  border-radius: var(--tellr-radius-full);
  background: var(--tellr-background);
  font-size: var(--tellr-text-sm);
  font-weight: var(--tellr-font-medium);
  color: var(--tellr-muted-foreground);
  box-shadow: var(--tellr-shadow-sm);
}

.tellr-hero__badge-dot {
  width: 0.5rem;
  height: 0.5rem;
  border-radius: var(--tellr-radius-full);
  background: var(--tellr-brand);
  animation: tellr-pulse 2s var(--tellr-ease-in-out) infinite;
}

.tellr-hero__title {
  margin: 0;
  font-size: clamp(var(--tellr-text-3xl), 5vw, var(--tellr-text-5xl));
  font-weight: var(--tellr-font-bold);
  line-height: var(--tellr-leading-tight);
  letter-spacing: var(--tellr-tracking-tight);
}

.tellr-hero__title-accent {
  background: linear-gradient(135deg, var(--tellr-foreground) 0%, var(--tellr-brand) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.tellr-hero__subtitle {
  margin: 0;
  font-size: var(--tellr-text-lg);
  line-height: var(--tellr-leading-relaxed);
  color: var(--tellr-muted-foreground);
  text-wrap: balance;
}

/* ── Buttons ───────────────────────────────────────────────────────────────── */

.tellr-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--tellr-space-2);
  padding: var(--tellr-space-2) var(--tellr-space-4);
  border: none;
  border-radius: var(--tellr-radius-md);
  font-size: var(--tellr-text-sm);
  font-weight: var(--tellr-font-medium);
  line-height: var(--tellr-leading-normal);
  cursor: pointer;
  white-space: nowrap;
  transition: opacity var(--tellr-duration-fast) var(--tellr-ease-out),
    transform var(--tellr-duration-fast) var(--tellr-ease-out),
    box-shadow var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.tellr-btn--primary {
  background: var(--tellr-gradient-cta);
  color: var(--tellr-primary-foreground);
  box-shadow: var(--tellr-shadow-sm);
}

.tellr-btn--primary:hover:not(:disabled) {
  box-shadow: var(--tellr-shadow-md), var(--tellr-shadow-glow);
  transform: translateY(-1px);
}

.tellr-btn--secondary {
  background: var(--tellr-secondary);
  color: var(--tellr-secondary-foreground);
  border: 1px solid var(--tellr-border);
}

.tellr-btn--ghost {
  background: transparent;
  color: var(--tellr-foreground);
}

.tellr-btn--ghost:hover {
  background: var(--tellr-accent);
}

.tellr-btn--lg {
  padding: var(--tellr-space-3) var(--tellr-space-6);
  font-size: var(--tellr-text-base);
}

/* ── Input ─────────────────────────────────────────────────────────────────── */

.tellr-input {
  width: 100%;
  padding: var(--tellr-space-2) var(--tellr-space-3);
  border: 1px solid var(--tellr-input);
  border-radius: var(--tellr-radius-md);
  background: var(--tellr-background);
  color: var(--tellr-foreground);
  font-size: var(--tellr-text-sm);
  outline: none;
  transition: border-color var(--tellr-duration-fast) var(--tellr-ease-out),
    box-shadow var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-input::placeholder {
  color: var(--tellr-muted-foreground);
}

.tellr-input:focus {
  border-color: var(--tellr-ring);
  box-shadow: 0 0 0 3px oklch(from var(--tellr-ring) l c h / 25%);
}

/* ── Newsletter Form ───────────────────────────────────────────────────────── */

.tellr-newsletter {
  width: 100%;
  max-width: 28rem;
}

.tellr-newsletter__group {
  display: flex;
  gap: var(--tellr-space-2);
  padding: var(--tellr-space-1);
  border: 1px solid var(--tellr-border);
  border-radius: var(--tellr-radius-lg);
  background: var(--tellr-background);
  box-shadow: var(--tellr-shadow-sm);
}

.tellr-newsletter__group .tellr-input {
  flex: 1;
  border: none;
  box-shadow: none;
  background: transparent;
}

.tellr-newsletter__group .tellr-input:focus {
  box-shadow: none;
}

.tellr-newsletter__hint {
  margin: var(--tellr-space-3) 0 0;
  font-size: var(--tellr-text-sm);
  color: var(--tellr-muted-foreground);
}

.tellr-newsletter__message {
  margin-top: var(--tellr-space-3);
  padding: var(--tellr-space-3);
  border-radius: var(--tellr-radius-md);
  font-size: var(--tellr-text-sm);
}

.tellr-newsletter__message--success {
  background: oklch(0.95 0.05 145);
  color: oklch(0.35 0.1 145);
  border: 1px solid oklch(0.85 0.08 145);
}

.tellr-newsletter__message--error {
  background: oklch(0.95 0.05 27);
  color: oklch(0.45 0.15 27);
  border: 1px solid oklch(0.85 0.1 27);
}

/* ── Section ───────────────────────────────────────────────────────────────── */

.tellr-section {
  padding-block: var(--tellr-space-16);
}

.tellr-section--muted {
  background: var(--tellr-muted);
}

.tellr-section__header {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--tellr-space-3);
  margin-bottom: var(--tellr-space-10);
  text-align: left;
}

.tellr-section__header--center {
  align-items: center;
  text-align: center;
}

.tellr-section__title {
  margin: 0;
  font-size: var(--tellr-text-2xl);
  font-weight: var(--tellr-font-semibold);
  letter-spacing: var(--tellr-tracking-tight);
}

.tellr-section__desc {
  margin: 0;
  max-width: 36rem;
  font-size: var(--tellr-text-base);
  color: var(--tellr-muted-foreground);
}

/* ── Cards / Archive Grid ────────────────────────────────────────────────────── */

.tellr-grid {
  display: grid;
  gap: var(--tellr-space-6);
  grid-template-columns: 1fr;
}

@media (min-width: 640px) {
  .tellr-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .tellr-grid,
  .tellr-grid--archive {
    grid-template-columns: repeat(4, 1fr);
  }
}

.tellr-card {
  position: relative;
  display: flex;
  flex-direction: column;
  border: 1px solid var(--tellr-border);
  border-radius: var(--tellr-radius-xl);
  background: var(--tellr-card);
  overflow: hidden;
  transition: transform var(--tellr-duration-normal) var(--tellr-ease-out),
    box-shadow var(--tellr-duration-normal) var(--tellr-ease-out),
    border-color var(--tellr-duration-normal) var(--tellr-ease-out);
}

.tellr-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: var(--tellr-gradient-border);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity: 0;
  transition: opacity var(--tellr-duration-normal) var(--tellr-ease-out);
  pointer-events: none;
}

.tellr-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--tellr-shadow-lg);
}

.tellr-card:hover::before {
  opacity: 1;
}

.tellr-card__media {
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: var(--tellr-muted);
}

.tellr-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--tellr-duration-slow) var(--tellr-ease-out);
}

.tellr-card:hover .tellr-card__media img {
  transform: scale(1.05);
}

.tellr-card__body {
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: var(--tellr-space-3);
  padding: var(--tellr-space-5);
}

.tellr-card__issue {
  font-family: var(--tellr-font-mono);
  font-size: var(--tellr-text-xs);
  font-weight: var(--tellr-font-medium);
  color: var(--tellr-brand);
  text-transform: uppercase;
  letter-spacing: var(--tellr-tracking-wide);
}

.tellr-card__title {
  margin: 0;
  font-size: var(--tellr-text-lg);
  font-weight: var(--tellr-font-semibold);
  line-height: var(--tellr-leading-snug);
  letter-spacing: var(--tellr-tracking-tight);
}

.tellr-card__title a {
  color: inherit;
  transition: color var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-card__title a:hover {
  color: var(--tellr-brand);
}

.tellr-card__excerpt {
  margin: 0;
  font-size: var(--tellr-text-sm);
  color: var(--tellr-muted-foreground);
  line-height: var(--tellr-leading-relaxed);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.tellr-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: auto;
  padding-top: var(--tellr-space-3);
  border-top: 1px solid var(--tellr-border);
}

/* ── Badge / Meta ──────────────────────────────────────────────────────────── */

.tellr-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.3125rem 0.75rem;
  border-radius: var(--tellr-radius-full);
  background: var(--tellr-brand-muted);
  font-size: var(--tellr-text-xs);
  font-weight: var(--tellr-font-medium);
  line-height: 1.25;
  color: var(--tellr-brand);
  text-decoration: none;
  transition:
    color var(--tellr-duration-fast) var(--tellr-ease-out),
    background var(--tellr-duration-fast) var(--tellr-ease-out),
    border-color var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-badge:hover {
  color: var(--tellr-brand);
  background: oklch(from var(--tellr-brand) l c h / 18%);
}

.tellr-badge--tag {
  border: 1px solid var(--tellr-border);
  background: var(--tellr-background);
  color: var(--tellr-muted-foreground);
}

.tellr-badge--tag:hover {
  color: var(--tellr-brand);
  border-color: var(--tellr-brand);
  background: var(--tellr-brand-muted);
}

.tellr-meta {
  font-size: var(--tellr-text-xs);
  color: var(--tellr-muted-foreground);
}

.tellr-meta--categories,
.tellr-meta--tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--tellr-space-2);
}

/* ── Single Post ─────────────────────────────────────────────────────────────── */

.tellr-article {
  padding-block: var(--tellr-space-12);
}

.tellr-article__header {
  margin-bottom: var(--tellr-space-8);
  text-align: left;
}

.tellr-article__header--page {
  margin-bottom: var(--tellr-space-10);
}

.tellr-article--single .tellr-article__header {
  max-width: none;
  margin-inline: 0;
}

.tellr-article__header .tellr-meta--categories {
  margin-bottom: var(--tellr-space-4);
}

.tellr-article__title {
  margin: 0 0 var(--tellr-space-4);
  font-size: clamp(var(--tellr-text-2xl), 4vw, var(--tellr-text-4xl));
  font-weight: var(--tellr-font-bold);
  line-height: var(--tellr-leading-tight);
  letter-spacing: var(--tellr-tracking-tight);
}

.tellr-article__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: var(--tellr-space-4);
}

.tellr-article__featured {
  margin-bottom: var(--tellr-space-8);
  border-radius: var(--tellr-radius-xl);
  overflow: hidden;
  box-shadow: var(--tellr-shadow-lg);
}

.tellr-article__content,
.tellr-prose {
  max-width: var(--tellr-content-width);
  font-size: var(--tellr-text-lg);
  line-height: var(--tellr-leading-relaxed);
}

.tellr-article--single .tellr-article__content {
  max-width: none;
  margin-inline: 0;
}

.tellr-article__footer {
  margin-top: var(--tellr-space-10);
  padding-top: var(--tellr-space-8);
  border-top: 1px solid var(--tellr-border);
}

.tellr-article__tags {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--tellr-space-3) var(--tellr-space-4);
}

.tellr-article__tags-label {
  font-size: var(--tellr-text-sm);
  font-weight: var(--tellr-font-semibold);
  color: var(--tellr-foreground);
}

.tellr-article__content h2,
.tellr-article__content h3,
.tellr-article__content h4,
.tellr-prose h2,
.tellr-prose h3,
.tellr-prose h4 {
  margin-top: var(--tellr-space-10);
  margin-bottom: var(--tellr-space-4);
  font-weight: var(--tellr-font-semibold);
  letter-spacing: var(--tellr-tracking-tight);
}

.tellr-article__content p,
.tellr-prose p {
  margin-bottom: var(--tellr-space-6);
}

.tellr-article__content a,
.tellr-prose a {
  color: var(--tellr-brand);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.tellr-article__content blockquote,
.tellr-prose blockquote {
  margin: var(--tellr-space-8) 0;
  padding: var(--tellr-space-4) var(--tellr-space-6);
  border-left: 3px solid var(--tellr-brand);
  background: var(--tellr-muted);
  border-radius: 0 var(--tellr-radius-md) var(--tellr-radius-md) 0;
  font-style: italic;
}

.tellr-article__content img,
.tellr-prose img {
  border-radius: var(--tellr-radius-lg);
  margin-block: var(--tellr-space-8);
}

/* ── Sidebar ───────────────────────────────────────────────────────────────── */

.tellr-sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--tellr-space-6);
}

@media (min-width: 1024px) {
  .tellr-sidebar {
    position: sticky;
    top: calc(var(--tellr-header-height) + var(--tellr-space-6));
  }
}

.tellr-sidebar__block {
  padding: var(--tellr-space-5);
  border: 1px solid var(--tellr-border);
  border-radius: var(--tellr-radius-xl);
  background: var(--tellr-card);
}

.tellr-sidebar__title {
  margin: 0 0 var(--tellr-space-4);
  font-size: var(--tellr-text-lg);
  font-weight: var(--tellr-font-semibold);
  line-height: var(--tellr-leading-snug);
  letter-spacing: var(--tellr-tracking-tight);
  color: var(--tellr-foreground);
}

.tellr-sidebar__list {
  display: flex;
  flex-direction: column;
  gap: var(--tellr-space-3);
  margin: 0;
  padding: 0;
  list-style: none;
}

.tellr-sidebar__list a {
  display: block;
  font-size: var(--tellr-text-sm);
  line-height: var(--tellr-leading-snug);
  color: var(--tellr-muted-foreground);
  text-decoration: none;
  transition: color var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-sidebar__list a:hover {
  color: var(--tellr-brand);
}

.tellr-sidebar__tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--tellr-space-2);
}

.tellr-sidebar__tag {
  display: inline-flex;
  align-items: center;
  padding: var(--tellr-space-1) var(--tellr-space-3);
  border: 1px solid var(--tellr-border);
  border-radius: var(--tellr-radius-full);
  background: var(--tellr-background);
  font-size: var(--tellr-text-xs);
  color: var(--tellr-muted-foreground);
  text-decoration: none;
  transition:
    color var(--tellr-duration-fast) var(--tellr-ease-out),
    border-color var(--tellr-duration-fast) var(--tellr-ease-out),
    background var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-sidebar__tag:hover {
  color: var(--tellr-brand);
  border-color: var(--tellr-brand);
  background: var(--tellr-brand-muted);
}

/* ── Footer ────────────────────────────────────────────────────────────────── */

.tellr-footer {
  position: relative;
  margin-top: auto;
  overflow: hidden;
  border-top: 1px solid var(--tellr-border);
  background: var(--tellr-background);
  padding-block: var(--tellr-space-16) var(--tellr-space-8);
}

.tellr-footer__bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
}

.tellr-footer__gradient {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 75% 85% at 0% 100%, oklch(0.55 0.2 250 / 30%), transparent 55%),
    radial-gradient(ellipse 65% 75% at 100% 0%, oklch(0.62 0.17 280 / 24%), transparent 50%),
    radial-gradient(ellipse 50% 50% at 50% 50%, oklch(0.58 0.14 200 / 14%), transparent 60%),
    var(--tellr-gradient-hero);
  opacity: 1;
}

.tellr-footer__mesh {
  position: absolute;
  inset: 0;
  opacity: 0.5;
  background: var(--tellr-gradient-mesh);
}

.tellr-footer__particles {
  position: absolute;
  inset: 0;
}

.tellr-footer__particles canvas {
  display: block;
  width: 100%;
  height: 100%;
}

.tellr-orb--footer.tellr-orb--primary {
  top: auto;
  bottom: -120px;
  right: 5%;
  width: 360px;
  height: 360px;
}

.tellr-orb--footer.tellr-orb--secondary {
  top: -80px;
  left: -60px;
  width: 280px;
  height: 280px;
}

.tellr-footer__inner {
  position: relative;
  z-index: 1;
}

.tellr-footer__grid {
  display: grid;
  gap: var(--tellr-space-10);
}

@media (min-width: 640px) {
  .tellr-footer__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1024px) {
  .tellr-footer__grid {
    grid-template-columns: minmax(0, 1.75fr) repeat(3, minmax(0, 1fr));
    gap: var(--tellr-space-12);
  }
}

.tellr-footer__brand {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: var(--tellr-space-5);
  text-align: left;
}

@media (max-width: 1023px) {
  .tellr-footer__brand {
    grid-column: 1 / -1;
  }
}

.tellr-footer__brand-head {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--tellr-space-4);
  max-width: 24rem;
}

.tellr-logo--footer {
  align-self: flex-start;
  justify-content: flex-start;
  max-width: 168px;
  margin-inline: 0;
}

.tellr-logo--footer img,
.tellr-logo--footer .tellr-logo__image,
.tellr-logo--footer .custom-logo {
  margin-inline: 0;
}

.tellr-footer__intro {
  margin: 0;
  max-width: 24rem;
  font-size: var(--tellr-text-sm);
  color: var(--tellr-muted-foreground);
  line-height: var(--tellr-leading-relaxed);
  text-align: left;
}

.tellr-footer__desc {
  margin: 0;
  max-width: 22rem;
  font-size: var(--tellr-text-sm);
  color: var(--tellr-muted-foreground);
  line-height: var(--tellr-leading-relaxed);
}

.tellr-footer__social {
  display: flex;
  flex-wrap: wrap;
  gap: var(--tellr-space-2);
  margin-top: var(--tellr-space-1);
}

.tellr-footer__social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  border: 1px solid var(--tellr-border);
  border-radius: var(--tellr-radius-full);
  background: var(--tellr-background);
  color: var(--tellr-muted-foreground);
  transition:
    color var(--tellr-duration-fast) var(--tellr-ease-out),
    border-color var(--tellr-duration-fast) var(--tellr-ease-out),
    background var(--tellr-duration-fast) var(--tellr-ease-out),
    transform var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-footer__social-link:hover {
  color: var(--tellr-brand);
  border-color: var(--tellr-brand);
  background: var(--tellr-brand-muted);
  transform: translateY(-1px);
}

.tellr-footer__col {
  min-width: 0;
}

.tellr-footer__heading {
  margin: 0 0 var(--tellr-space-4);
  font-size: var(--tellr-text-lg);
  font-weight: var(--tellr-font-semibold);
  line-height: var(--tellr-leading-snug);
  letter-spacing: var(--tellr-tracking-tight);
  color: var(--tellr-foreground);
}

.tellr-footer__links {
  display: flex;
  flex-direction: column;
  gap: var(--tellr-space-2);
  margin: 0;
  padding: 0;
  list-style: none;
}

.tellr-footer__links li,
.tellr-footer__links .menu-item {
  margin: 0;
  padding: 0;
  list-style: none;
}

.tellr-footer__links a,
.tellr-footer__links .menu-item a {
  display: inline-block;
  font-size: var(--tellr-text-sm);
  line-height: var(--tellr-leading-snug);
  color: var(--tellr-muted-foreground);
  text-decoration: none;
  transition: color var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-footer__links a:hover,
.tellr-footer__links .menu-item a:hover {
  color: var(--tellr-brand);
}

.tellr-footer__posts {
  display: flex;
  flex-direction: column;
  gap: var(--tellr-space-3);
  margin: 0;
  padding: 0;
  list-style: none;
}

.tellr-footer-post__link {
  display: flex;
  align-items: center;
  gap: var(--tellr-space-3);
  color: inherit;
  text-decoration: none;
  transition: color var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-footer-post__link:hover {
  color: var(--tellr-brand);
}

.tellr-footer-post__link:hover .tellr-footer-post__title {
  color: var(--tellr-brand);
}

.tellr-footer-post__media {
  flex-shrink: 0;
  width: 4.5rem;
  height: 4.5rem;
  overflow: hidden;
  border-radius: var(--tellr-radius-md);
  border: 1px solid var(--tellr-border);
  background: var(--tellr-muted);
}

.tellr-footer-post__thumb {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.tellr-footer-post__placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  font-size: var(--tellr-text-lg);
  font-weight: var(--tellr-font-semibold);
  color: var(--tellr-brand);
  background: var(--tellr-brand-muted);
}

.tellr-footer-post__title {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  /* stylelint-disable-next-line property-no-vendor-prefix */
  -webkit-box-orient: vertical;
  overflow: hidden;
  font-size: var(--tellr-text-sm);
  line-height: var(--tellr-leading-snug);
  color: var(--tellr-muted-foreground);
  transition: color var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-footer__tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--tellr-space-2);
}

.tellr-footer__tag {
  display: inline-flex;
  align-items: center;
  padding: var(--tellr-space-1) var(--tellr-space-3);
  border: 1px solid var(--tellr-border);
  border-radius: var(--tellr-radius-full);
  background: var(--tellr-background);
  font-size: var(--tellr-text-xs);
  color: var(--tellr-muted-foreground);
  text-decoration: none;
  transition:
    color var(--tellr-duration-fast) var(--tellr-ease-out),
    border-color var(--tellr-duration-fast) var(--tellr-ease-out),
    background var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-footer__tag:hover {
  color: var(--tellr-brand);
  border-color: var(--tellr-brand);
  background: var(--tellr-brand-muted);
}

.tellr-footer__bottom {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--tellr-space-4);
  margin-top: var(--tellr-space-12);
  padding-top: var(--tellr-space-8);
  border-top: 1px solid oklch(from var(--tellr-border) l c h / 70%);
  font-size: var(--tellr-text-sm);
  color: var(--tellr-muted-foreground);
}

@media (min-width: 768px) {
  .tellr-footer__bottom {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
}

.tellr-footer__copy {
  margin: 0;
}

.tellr-footer__copy a {
  color: var(--tellr-foreground);
  font-weight: var(--tellr-font-medium);
  text-decoration: none;
}

.tellr-footer__copy a:hover {
  color: var(--tellr-brand);
}

.tellr-footer__legal {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--tellr-space-4);
}

.tellr-footer__legal a {
  color: var(--tellr-muted-foreground);
  font-size: var(--tellr-text-sm);
  text-decoration: none;
  transition: color var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-footer__legal a:hover {
  color: var(--tellr-brand);
}

.tellr-footer__legal a + a::before {
  content: "·";
  margin-right: var(--tellr-space-4);
  color: var(--tellr-border);
  pointer-events: none;
}

.tellr-footer__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--tellr-space-4);
}

.tellr-footer__meta a {
  color: var(--tellr-muted-foreground);
  text-decoration: none;
  transition: color var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-footer__meta a:hover {
  color: var(--tellr-brand);
}

/* ── Pagination ──────────────────────────────────────────────────────────────── */

.tellr-pagination {
  display: flex;
  justify-content: center;
  gap: var(--tellr-space-2);
  margin-top: var(--tellr-space-12);
}

.tellr-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.25rem;
  height: 2.25rem;
  padding-inline: var(--tellr-space-2);
  border: 1px solid var(--tellr-border);
  border-radius: var(--tellr-radius-md);
  font-size: var(--tellr-text-sm);
  color: var(--tellr-muted-foreground);
  transition: background var(--tellr-duration-fast) var(--tellr-ease-out),
    color var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-pagination .page-numbers:hover,
.tellr-pagination .page-numbers.current {
  background: var(--tellr-primary);
  color: var(--tellr-primary-foreground);
  border-color: var(--tellr-primary);
}

/* ── 404 / Search ────────────────────────────────────────────────────────────── */

.tellr-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding-block: var(--tellr-space-24);
  gap: var(--tellr-space-6);
}

.tellr-empty__title {
  margin: 0;
  font-size: var(--tellr-text-4xl);
  font-weight: var(--tellr-font-bold);
}

.tellr-empty__desc {
  margin: 0;
  max-width: 24rem;
  color: var(--tellr-muted-foreground);
}

/* ── 404 Page ────────────────────────────────────────────────────────────────── */

.tellr-not-found {
  position: relative;
  overflow: hidden;
  padding-block: var(--tellr-space-20) var(--tellr-space-24);
}

.tellr-not-found__bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.tellr-not-found__gradient {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 70% at 50% 0%, oklch(0.55 0.2 250 / 30%), transparent 60%),
    radial-gradient(ellipse 60% 50% at 100% 100%, oklch(0.62 0.17 280 / 22%), transparent 55%),
    radial-gradient(ellipse 55% 45% at 0% 100%, oklch(0.58 0.15 200 / 18%), transparent 50%),
    var(--tellr-gradient-hero);
}

.tellr-not-found__mesh {
  position: absolute;
  inset: 0;
  opacity: 0.5;
  background: var(--tellr-gradient-mesh);
}

.tellr-not-found__particles {
  position: absolute;
  inset: 0;
}

.tellr-not-found__particles canvas {
  display: block;
  width: 100%;
  height: 100%;
}

.tellr-orb--not-found.tellr-orb--primary {
  top: 10%;
  right: 8%;
  width: 320px;
  height: 320px;
}

.tellr-orb--not-found.tellr-orb--secondary {
  bottom: 5%;
  left: 6%;
  width: 260px;
  height: 260px;
}

.tellr-not-found__inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--tellr-space-6);
}

.tellr-not-found__code {
  margin: 0;
  font-size: clamp(4rem, 16vw, 8rem);
  font-weight: var(--tellr-font-bold);
  line-height: 1;
  letter-spacing: var(--tellr-tracking-tight);
  background: linear-gradient(135deg, var(--tellr-foreground) 0%, var(--tellr-brand) 55%, oklch(0.62 0.17 280) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.tellr-not-found__title {
  margin: 0;
  max-width: 28rem;
  font-size: clamp(var(--tellr-text-2xl), 4vw, var(--tellr-text-4xl));
  font-weight: var(--tellr-font-semibold);
  line-height: var(--tellr-leading-tight);
  letter-spacing: var(--tellr-tracking-tight);
}

.tellr-not-found__desc {
  margin: 0;
  max-width: 34rem;
  font-size: var(--tellr-text-base);
  line-height: var(--tellr-leading-relaxed);
  color: var(--tellr-muted-foreground);
}

.tellr-not-found__search {
  justify-content: center;
  max-width: 32rem;
  width: 100%;
  margin-top: var(--tellr-space-2);
}

.tellr-not-found__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--tellr-space-3);
}

.tellr-not-found__suggestions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--tellr-space-4);
  width: 100%;
  max-width: 40rem;
  margin-top: var(--tellr-space-4);
  padding-top: var(--tellr-space-8);
  border-top: 1px solid oklch(from var(--tellr-border) l c h / 70%);
}

.tellr-not-found__suggestions-title {
  margin: 0;
  font-size: var(--tellr-text-sm);
  font-weight: var(--tellr-font-semibold);
  color: var(--tellr-muted-foreground);
  text-transform: uppercase;
  letter-spacing: var(--tellr-tracking-wide);
}

.tellr-not-found__tags {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--tellr-space-2);
}

.tellr-search-form {
  display: flex;
  gap: var(--tellr-space-2);
  max-width: 28rem;
  width: 100%;
}

/* ── Benefits Row (Newsletter CTA) ───────────────────────────────────────────── */

.tellr-benefits {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--tellr-space-4) var(--tellr-space-6);
  margin-top: var(--tellr-space-6);
}

.tellr-benefits__item {
  display: inline-flex;
  align-items: center;
  gap: var(--tellr-space-2);
  font-size: var(--tellr-text-sm);
  color: var(--tellr-muted-foreground);
}

.tellr-benefits__check {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.125rem;
  height: 1.125rem;
  border-radius: var(--tellr-radius-full);
  background: oklch(0.95 0.05 145);
  color: oklch(0.45 0.15 145);
}

.tellr-benefits__check svg {
  width: 0.75rem;
  height: 0.75rem;
}

/* ── Compact Hero ────────────────────────────────────────────────────────────── */

.tellr-hero--compact {
  padding-block: var(--tellr-space-12) var(--tellr-space-10);
}

.tellr-hero--featured .tellr-container {
  position: relative;
  z-index: 1;
}

.tellr-hero__featured {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: var(--tellr-space-8);
  align-items: center;
}

.tellr-hero__featured-body {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--tellr-space-4);
  text-align: left;
}

.tellr-hero__title-link {
  color: inherit;
  text-decoration: none;
  transition: color var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-hero__title-link:hover {
  color: var(--tellr-brand);
}

.tellr-hero--featured .tellr-hero__title {
  font-size: clamp(var(--tellr-text-2xl), 3.5vw, var(--tellr-text-4xl));
}

.tellr-hero--featured .tellr-hero__subtitle {
  max-width: 36rem;
  font-size: var(--tellr-text-base);
  text-align: left;
}

.tellr-hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--tellr-space-4);
}

.tellr-hero__featured-media {
  display: block;
  overflow: hidden;
  border-radius: var(--tellr-radius-xl);
  box-shadow: var(--tellr-shadow-lg);
  color: inherit;
  text-decoration: none;
}

.tellr-hero__featured-media img {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 10;
  object-fit: cover;
}

.tellr-hero__featured-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 16 / 10;
  background: var(--tellr-gradient-hero);
  color: var(--tellr-brand);
  font-size: var(--tellr-text-6xl);
  font-weight: var(--tellr-font-bold);
}

@media (max-width: 900px) {
  .tellr-hero__featured {
    grid-template-columns: 1fr;
    gap: var(--tellr-space-6);
  }

  .tellr-hero__featured-media {
    order: -1;
  }
}

/* ── Hero Slider (featured articles at top) ─────────────────────────────────── */

.tellr-hero--slider {
  padding-block: var(--tellr-space-8) var(--tellr-space-10);
}

.tellr-hero__slider-wrap {
  position: relative;
  z-index: 1;
}

.tellr-hero--slider .tellr-slider {
  position: relative;
}

.tellr-hero--slider .tellr-slider__track {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  position: relative;
  height: auto;
  min-height: 360px;
  overflow: hidden;
  background: transparent;
  border: none;
  box-shadow: none;
  border-radius: 0;
}

.tellr-hero--slider .tellr-slide {
  grid-area: 1 / 1;
  position: relative;
  inset: auto;
  width: 100%;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.tellr-hero--slider .tellr-slide.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  z-index: 1;
}

.tellr-hero--slider .tellr-slide__panel {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: var(--tellr-space-8);
  height: auto;
  min-height: 360px;
  color: inherit;
  text-decoration: none;
  align-items: center;
}

.tellr-hero--slider .tellr-slide__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: var(--tellr-space-4);
  padding: 0;
  text-align: left;
  background: transparent;
  border: none;
}

.tellr-hero--slider .tellr-slide__title {
  margin: 0;
  font-size: clamp(var(--tellr-text-2xl), 3.5vw, var(--tellr-text-4xl));
  font-weight: var(--tellr-font-bold);
  line-height: var(--tellr-leading-tight);
  letter-spacing: var(--tellr-tracking-tight);
  color: var(--tellr-foreground);
}

.tellr-hero--slider .tellr-slide__excerpt {
  margin: 0;
  max-width: 36rem;
  color: var(--tellr-muted-foreground);
  font-size: var(--tellr-text-base);
  line-height: var(--tellr-leading-relaxed);
}

.tellr-hero--slider .tellr-slide__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--tellr-space-4);
}

.tellr-hero--slider .tellr-slide__media {
  height: 100%;
  min-height: 320px;
  border-radius: var(--tellr-radius-xl);
  overflow: hidden;
  box-shadow: var(--tellr-shadow-lg);
}

.tellr-hero--slider .tellr-slide__overlay {
  display: none;
}

.tellr-hero--slider .tellr-slider__controls {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: var(--tellr-space-4);
  margin-top: var(--tellr-space-5);
}

.tellr-hero--slider .tellr-slider__btn {
  background: var(--tellr-background);
  border: 1px solid var(--tellr-border);
}

/* ── Featured Slider (legacy selectors kept for slide core) ─────────────────── */

.tellr-featured {
  padding-block: var(--tellr-space-8) var(--tellr-space-12);
}

.tellr-section__header--split,
.tellr-category-block .tellr-section__header {
  flex-direction: row;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--tellr-space-6);
  text-align: left;
}

.tellr-section__actions {
  display: flex;
  justify-content: center;
  margin-top: var(--tellr-space-10);
}

.tellr-section__actions--left {
  justify-content: flex-start;
}

.tellr-category-block:nth-child(even) {
  background: var(--tellr-muted);
}

/* ── Category Pills ────────────────────────────────────────────────────────────── */

.tellr-category-pills {
  padding-block: var(--tellr-space-4);
  border-bottom: 1px solid var(--tellr-border);
  background: var(--tellr-background);
}

.tellr-category-pills__track {
  display: flex;
  gap: var(--tellr-space-2);
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding-block: var(--tellr-space-1);
}

.tellr-category-pills__track::-webkit-scrollbar {
  display: none;
}

.tellr-category-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--tellr-space-2);
  padding: var(--tellr-space-2) var(--tellr-space-4);
  border: 1px solid var(--tellr-border);
  border-radius: var(--tellr-radius-full);
  background: var(--tellr-background);
  font-size: var(--tellr-text-sm);
  font-weight: var(--tellr-font-medium);
  white-space: nowrap;
  transition: border-color var(--tellr-duration-fast) var(--tellr-ease-out),
    background var(--tellr-duration-fast) var(--tellr-ease-out),
    transform var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-category-pill small {
  color: var(--tellr-muted-foreground);
  font-size: var(--tellr-text-xs);
}

.tellr-category-pill:hover,
.tellr-category-pill:focus-visible {
  border-color: var(--tellr-brand);
  background: var(--tellr-brand-muted);
}

/* ── Featured Slider ───────────────────────────────────────────────────────────── */

.tellr-featured {
  padding-block: var(--tellr-space-8) var(--tellr-space-12);
}

.tellr-slider {
  position: relative;
}

.tellr-slider__track {
  position: relative;
  min-height: 420px;
  border-radius: var(--tellr-radius-2xl);
  overflow: hidden;
  border: 1px solid var(--tellr-border);
  box-shadow: var(--tellr-shadow-xl);
}

.tellr-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--tellr-duration-slow) var(--tellr-ease-out),
    visibility var(--tellr-duration-slow);
}

.tellr-slide.is-active {
  opacity: 1;
  visibility: visible;
  z-index: 1;
}

.tellr-slide__panel,
.tellr-slide__link {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  height: 100%;
  min-height: 420px;
  color: inherit;
  text-decoration: none;
}

.tellr-slide__media {
  position: relative;
  overflow: hidden;
  background: var(--tellr-muted);
  min-height: 100%;
}

.tellr-slide__placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  min-height: 480px;
  background: var(--tellr-gradient-hero);
  color: var(--tellr-brand);
  font-size: var(--tellr-text-6xl);
  font-weight: var(--tellr-font-bold);
}

.tellr-slide__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 6s var(--tellr-ease-out);
}

.tellr-slide.is-active .tellr-slide__media img {
  transform: scale(1.05);
}

.tellr-slide__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(270deg, transparent 40%, var(--tellr-background) 100%);
}

.tellr-slide__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--tellr-space-4);
  padding: var(--tellr-space-8);
  background: var(--tellr-card);
}

.tellr-slide__title {
  margin: 0;
  font-size: clamp(var(--tellr-text-2xl), 3vw, var(--tellr-text-4xl));
  font-weight: var(--tellr-font-bold);
  line-height: var(--tellr-leading-tight);
  letter-spacing: var(--tellr-tracking-tight);
}

.tellr-slide__excerpt {
  margin: 0;
  color: var(--tellr-muted-foreground);
  font-size: var(--tellr-text-base);
  line-height: var(--tellr-leading-relaxed);
}

.tellr-slide__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--tellr-space-4);
}

.tellr-slider__controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--tellr-space-4);
  margin-top: var(--tellr-space-4);
}

.tellr-slider__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border: 1px solid var(--tellr-border);
  border-radius: var(--tellr-radius-full);
  background: var(--tellr-background);
  color: var(--tellr-foreground);
  cursor: pointer;
  transition: background var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-slider__btn:hover {
  background: var(--tellr-accent);
}

.tellr-slider__dots {
  display: flex;
  gap: var(--tellr-space-2);
}

.tellr-slider__dot {
  width: 0.5rem;
  height: 0.5rem;
  padding: 0;
  border: none;
  border-radius: var(--tellr-radius-full);
  background: var(--tellr-border);
  cursor: pointer;
  transition: background var(--tellr-duration-fast) var(--tellr-ease-out),
    transform var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-slider__dot.is-active {
  background: var(--tellr-brand);
  transform: scale(1.2);
}

@media (max-width: 900px) {
  .tellr-hero--slider .tellr-slide__panel,
  .tellr-slide__panel {
    grid-template-columns: 1fr;
    gap: var(--tellr-space-5);
    min-height: auto;
  }

  .tellr-hero--slider .tellr-slider__track {
    min-height: 0;
  }

  .tellr-hero--slider .tellr-slide__media {
    order: -1;
    min-height: 220px;
    aspect-ratio: 16 / 9;
  }

  .tellr-hero--slider .tellr-slide__content {
    position: static;
    padding: 0;
    background: transparent;
    border: none;
  }
}

/* ── Trending Scroll Row ───────────────────────────────────────────────────────── */

.tellr-scroll-row {
  position: relative;
}

.tellr-scroll-row__track {
  display: flex;
  gap: var(--tellr-space-4);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding-block: var(--tellr-space-2);
}

.tellr-scroll-row__track::-webkit-scrollbar {
  display: none;
}

.tellr-scroll-row__btn {
  position: absolute;
  top: 50%;
  z-index: 2;
  display: none;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border: 1px solid var(--tellr-border);
  border-radius: var(--tellr-radius-full);
  background: var(--tellr-background);
  color: var(--tellr-foreground);
  box-shadow: var(--tellr-shadow-md);
  cursor: pointer;
  transform: translateY(-50%);
}

@media (min-width: 768px) {
  .tellr-scroll-row__btn {
    display: inline-flex;
  }
}

.tellr-scroll-row__btn--prev { left: -0.75rem; }
.tellr-scroll-row__btn--next { right: -0.75rem; }

.tellr-scroll-card {
  display: flex;
  flex-direction: column;
  flex: 0 0 280px;
  scroll-snap-align: start;
  border: 1px solid var(--tellr-border);
  border-radius: var(--tellr-radius-xl);
  background: var(--tellr-card);
  color: var(--tellr-card-foreground);
  overflow: hidden;
  transition: transform var(--tellr-duration-normal) var(--tellr-ease-out),
    box-shadow var(--tellr-duration-normal) var(--tellr-ease-out);
}

.tellr-scroll-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--tellr-shadow-lg);
}

.tellr-scroll-card__media-link {
  display: block;
  color: inherit;
  text-decoration: none;
}

.tellr-scroll-card__media {
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--tellr-muted);
}

.tellr-scroll-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--tellr-duration-slow) var(--tellr-ease-out);
}

.tellr-scroll-card:hover .tellr-scroll-card__media img {
  transform: scale(1.04);
}

.tellr-scroll-card__placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  min-height: 175px;
  background: var(--tellr-gradient-hero);
  color: var(--tellr-brand);
  font-size: var(--tellr-text-4xl);
  font-weight: var(--tellr-font-bold);
}

.tellr-scroll-card__body {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: var(--tellr-space-2);
  padding: var(--tellr-space-4);
  color: var(--tellr-card-foreground);
  background: var(--tellr-card);
}

.tellr-scroll-card__title {
  margin: 0;
  font-size: var(--tellr-text-base);
  font-weight: var(--tellr-font-semibold);
  line-height: var(--tellr-leading-snug);
}

.tellr-scroll-card__title a {
  color: var(--tellr-foreground);
  text-decoration: none;
  transition: color var(--tellr-duration-fast) var(--tellr-ease-out);
}

.tellr-scroll-card__title a:hover {
  color: var(--tellr-brand);
}

.tellr-scroll-card__excerpt {
  margin: 0;
  font-size: var(--tellr-text-sm);
  line-height: var(--tellr-leading-relaxed);
  color: var(--tellr-muted-foreground);
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  /* stylelint-disable-next-line property-no-vendor-prefix */
  -webkit-box-orient: vertical;
}

.tellr-scroll-card__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--tellr-space-3);
  margin-top: auto;
  padding-top: var(--tellr-space-2);
  border-top: 1px solid var(--tellr-border);
}

.tellr-scroll-card__body .tellr-badge {
  color: var(--tellr-brand);
}

.tellr-mobile-nav .sub-menu {
  position: static;
  opacity: 1;
  visibility: visible;
  transform: none;
  box-shadow: none;
  border: none;
  padding-left: var(--tellr-space-4);
  background: transparent;
}

.tellr-mobile-nav .tellr-nav__list--mobile {
  flex-direction: column;
  align-items: stretch;
}

@media (max-width: 767px) {
  .tellr-category-block .tellr-section__header {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* Hero slider — overrides generic .tellr-slide rules above */
.tellr-hero--slider .tellr-slider__track {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  min-height: 360px;
  border: none;
  box-shadow: none;
}

.tellr-hero--slider .tellr-slide {
  position: relative;
  inset: auto;
  grid-area: 1 / 1;
  width: 100%;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.tellr-hero--slider .tellr-slide.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  z-index: 1;
}

.tellr-hero--slider .tellr-slide__panel {
  height: auto;
  min-height: 360px;
}

.tellr-hero--slider .tellr-slide__content {
  background: transparent;
}

.tellr-hero--slider .tellr-slide__media img {
  width: 100%;
  height: auto;
  min-height: 320px;
  max-height: 420px;
  object-fit: cover;
}

