.page--tutorials {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  min-height: calc(100dvh - 56px);
  min-height: calc(100dvh - var(--app-top-offset, 56px));
  padding-top: 32px;
  padding-bottom: 48px;
  box-sizing: border-box;
}

.tutorials-center {
  width: 100%;
  margin-inline: auto;
}

.page--tutorials .page__header h1 {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: clamp(26px, 4vw, 32px);
  font-weight: 600;
  letter-spacing: -0.03em;
  margin-bottom: 6px;
  color: var(--color-text);
}

.tutorials-page__icon {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  stroke-width: 2px;
  color: var(--color-text);
  opacity: 0.9;
}

.page--tutorials .page__subtitle {
  margin: 0;
  font-size: clamp(13px, 1.6vw, 15px);
  line-height: 1.5;
  letter-spacing: -0.01em;
  color: var(--color-text-muted);
}

.tutorials-page__intro {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 28px;
}

.tutorials-page__meta {
  display: flex;
  flex-shrink: 0;
  align-items: baseline;
  gap: 14px;
}

.tutorials-page__count {
  margin: 0;
  font-size: 13px;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: -0.01em;
  color: var(--color-text-muted);
  text-align: right;
  white-space: nowrap;
}

.tutorials-page__browse-all {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.5;
  color: var(--color-accent);
  text-decoration: none;
  white-space: nowrap;
  transition: color 0.15s ease;
}

.tutorials-page__browse-all:hover {
  color: color-mix(in srgb, var(--color-accent) 75%, var(--color-text));
}

.tutorials-page__browse-all:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
  border-radius: 2px;
}

.tutorials-page__browse-all[hidden] {
  display: none;
}

.tutorials-content {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

/* ── Featured tutorial ────────────────────────────── */

.tutorials-featured {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.15fr);
  align-items: start;
  overflow: hidden;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.06);
}

.tutorials-featured__body {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 24px 28px;
}

.tutorials-featured__eyebrow {
  margin: 0 0 8px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.tutorials-featured__title {
  margin: 0;
  font-size: clamp(20px, 2.8vw, 26px);
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 1.2;
  color: var(--color-text);
}

.tutorials-featured__desc {
  margin: 12px 0 0;
  max-width: 38ch;
  font-size: 14px;
  line-height: 1.55;
  color: color-mix(in srgb, var(--color-text-muted) 75%, var(--color-text));
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.tutorials-featured__cta {
  display: inline-flex;
  align-self: flex-start;
  margin-top: 18px;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--color-text);
  text-decoration: none;
  transition: color 0.15s ease;
}

.tutorials-featured__cta::after {
  content: " →";
}

.tutorials-featured__cta:hover {
  color: var(--color-accent);
}

.tutorials-featured__media {
  aspect-ratio: 16 / 9;
  width: 100%;
  min-height: 0;
  align-self: start;
  background: var(--color-text);
}

/* ── Search ───────────────────────────────────────── */

.tutorials-search-row {
  display: flex;
  align-items: stretch;
  gap: 10px;
  width: 100%;
}

.tutorials-search-wrap {
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
  min-width: 0;
}

.tutorials-search-row .tutorials-search-wrap {
  gap: 0;
}

.tutorials-search-row .tutorials-search {
  height: 100%;
  min-height: 40px;
  box-sizing: border-box;
}

.tutorials-search-row__filters {
  display: flex;
  align-items: stretch;
  flex-wrap: wrap;
  gap: 10px;
  flex-shrink: 0;
}

.tutorials-sort {
  position: relative;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
  padding: 0 10px;
  min-height: 40px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
  color: var(--color-text);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.tutorials-sort__label {
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text-muted);
  white-space: nowrap;
}

.tutorials-sort[data-filter="duration"] .tutorials-sort__trigger {
  min-width: 9.5rem;
}

.tutorials-sort__trigger {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-width: 6.5rem;
  padding: 6px 4px 6px 2px;
  border: none;
  background: transparent;
  color: var(--color-text);
  font: inherit;
  font-size: 14px;
  font-weight: 500;
  text-align: left;
  cursor: pointer;
}

.tutorials-sort__value {
  flex: 1;
  min-width: 0;
}

.tutorials-sort__chevron {
  display: flex;
  flex-shrink: 0;
  color: var(--color-text-muted);
  transition: transform 0.15s ease;
}

.tutorials-sort__chevron svg {
  width: 14px;
  height: 14px;
}

.tutorials-sort.is-open .tutorials-sort__chevron {
  transform: rotate(180deg);
}

.tutorials-sort__trigger:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

.tutorials-sort.is-open,
.tutorials-sort:focus-within {
  border-color: color-mix(in srgb, var(--color-accent) 40%, var(--color-border));
}

.tutorials-sort__menu {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  z-index: 20;
  min-width: 100%;
  margin: 0;
  padding: 6px;
  list-style: none;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
  box-shadow: 0 10px 28px color-mix(in srgb, var(--color-text) 14%, transparent);
}

.tutorials-sort__option {
  display: block;
  width: 100%;
  padding: 9px 12px;
  border: none;
  border-radius: var(--radius-md);
  background: transparent;
  color: var(--color-text);
  font: inherit;
  font-size: 14px;
  font-weight: 500;
  text-align: left;
  cursor: pointer;
}

.tutorials-sort__option:hover {
  background: color-mix(in srgb, var(--color-accent) 8%, var(--color-surface));
}

.tutorials-sort__option.is-active {
  color: var(--color-accent);
  background: color-mix(in srgb, var(--color-accent) 10%, var(--color-surface));
}

.tutorials-sort__option:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 1px;
}

.tutorials-search {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 14px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
  transition:
    border-color 0.15s ease,
    box-shadow 0.15s ease;
}

.tutorials-search:focus-within {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-accent) 18%, transparent);
}

.tutorials-search__icon {
  display: flex;
  flex-shrink: 0;
  color: var(--color-text-muted);
}

.tutorials-search__icon svg {
  width: 18px;
  height: 18px;
}

.tutorials-search__input {
  flex: 1;
  min-width: 0;
  padding: 10px 0;
  border: 0;
  background: transparent;
  color: var(--color-text);
  font: inherit;
  font-size: 15px;
  letter-spacing: -0.01em;
  outline: none;
}

.tutorials-search__input::placeholder {
  color: color-mix(in srgb, var(--color-text-muted) 85%, transparent);
}

/* ── Category nav (homepage) ──────────────────────── */

.tutorials-browse-wrap {
  margin: 8px 0 4px;
}

.tutorials-browse-wrap[hidden] {
  display: none;
}

.tutorials-browse-wrap .tutorials-home-section {
  margin-top: 0;
}

.tutorials-browse-wrap .tutorials-home-section__title {
  margin-bottom: 12px;
}

.tutorials-home-section {
  margin-top: 8px;
}

.tutorials-home-section + .tutorials-home-section {
  margin-top: 28px;
  padding-top: 28px;
  border-top: 1px solid color-mix(in srgb, var(--color-border) 75%, transparent);
}

.tutorials-home-section__title {
  margin: 0 0 14px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--color-text-muted) 80%, var(--color-text));
}

.tutorials-home-section--category .tutorials-home-section__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.tutorials-home-section--category .tutorials-home-section__title {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0;
  font-size: clamp(15px, 2vw, 17px);
  font-weight: 600;
  letter-spacing: -0.02em;
  text-transform: none;
  color: var(--color-text);
}

.tutorials-home-section__icon {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  color: inherit;
}

.tutorials-home-section__icon svg {
  width: 20px;
  height: 20px;
}

.tutorials-home-section__icon .tutorials-browse-card__icon-img {
  width: 22px;
  height: 22px;
}

.tutorials-home-section__label {
  min-width: 0;
}

.tutorials-home-section__link {
  flex-shrink: 0;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.4;
  color: var(--color-accent);
  text-decoration: none;
  white-space: nowrap;
  transition: color 0.15s ease;
}

.tutorials-home-section__link:hover {
  color: color-mix(in srgb, var(--color-accent) 75%, var(--color-text));
}

.tutorials-home-section__link:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
  border-radius: 2px;
}

.tutorials-main {
  margin-top: 8px;
}

.tutorials-browse-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.tutorials-browse-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md, 8px);
  background: color-mix(in srgb, var(--color-text) 3%, var(--color-surface));
  text-decoration: none;
  color: inherit;
  transition:
    border-color 0.15s ease,
    transform 0.15s ease,
    box-shadow 0.15s ease;
}

.tutorials-browse-card:hover {
  border-color: color-mix(in srgb, var(--color-accent) 45%, var(--color-border));
  transform: translateY(-1px);
  box-shadow: 0 6px 18px color-mix(in srgb, var(--color-text) 8%, transparent);
}

.tutorials-browse-card--all {
  border-color: color-mix(in srgb, var(--color-accent) 30%, var(--color-border));
  background: color-mix(in srgb, var(--color-accent) 4%, var(--color-surface));
}

button.tutorials-browse-card {
  width: 100%;
  font: inherit;
  text-align: left;
  cursor: pointer;
}

.tutorials-browse-card--more {
  border-color: color-mix(in srgb, var(--color-text-muted) 28%, var(--color-border));
  background: color-mix(in srgb, var(--color-text) 2%, var(--color-surface));
}

.tutorials-browse-card--more:hover {
  border-color: color-mix(in srgb, var(--color-accent) 35%, var(--color-border));
}

.tutorials-browse-card__icon {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: transparent;
  color: inherit;
}

.tutorials-browse-card__icon svg {
  width: 22px;
  height: 22px;
}

.tutorials-browse-card__icon-img {
  display: block;
  width: 24px;
  height: 24px;
  object-fit: contain;
  object-position: center;
}

.tutorials-browse-card__body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.tutorials-browse-card__title {
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.3;
  color: var(--color-text);
}

.tutorials-browse-card__count {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.35;
  font-variant-numeric: tabular-nums;
  color: color-mix(in srgb, var(--color-text) 55%, var(--color-text-muted));
}

.tutorials-browse-card:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}

.tutorials-back-link {
  display: inline-block;
  margin-bottom: 16px;
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text-muted);
  text-decoration: none;
  transition: color 0.15s ease;
}

.tutorials-back-link:hover {
  color: var(--color-accent);
}

.tutorials-breadcrumbs {
  margin-bottom: 18px;
}

.tutorials-breadcrumbs__list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  margin: 0;
  padding: 0;
  list-style: none;
  font-size: 13px;
  line-height: 1.4;
}

.tutorials-breadcrumbs__item {
  display: inline-flex;
  align-items: center;
  color: var(--color-text-muted);
}

.tutorials-breadcrumbs__item:not(:last-child)::after {
  content: "/";
  margin: 0 8px;
  color: color-mix(in srgb, var(--color-text-muted) 45%, transparent);
  font-weight: 500;
  user-select: none;
}

.tutorials-breadcrumbs__link {
  font-weight: 600;
  color: var(--color-text-muted);
  text-decoration: none;
  transition: color 0.15s ease;
}

.tutorials-breadcrumbs__link:hover {
  color: var(--color-accent);
}

.tutorials-breadcrumbs__current {
  font-weight: 600;
  color: var(--color-text);
}

/* ── All Tutorials — topic hub ────────────────────── */

.tutorials-library-hub {
  margin: 0 0 10px;
  padding: 18px 18px 16px;
  border: 1px solid color-mix(in srgb, var(--color-border) 85%, transparent);
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--color-text) 2.5%, var(--color-surface));
  box-shadow: 0 2px 10px color-mix(in srgb, var(--color-text) 4%, transparent);
}

.tutorials-library-hub__header {
  margin-bottom: 14px;
}

.tutorials-library-hub__title {
  margin: 0 0 6px;
  font-size: clamp(18px, 2.4vw, 22px);
  font-weight: 650;
  letter-spacing: -0.03em;
  color: var(--color-text);
}

.tutorials-library-hub__lede {
  margin: 0;
  max-width: 62ch;
  font-size: 14px;
  line-height: 1.55;
  color: var(--color-text-muted);
}

.tutorials-library-hub__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.tutorials-library-hub__card {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  width: 100%;
  padding: 16px 16px 15px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md, 10px);
  background: var(--color-surface);
  text-align: left;
  font: inherit;
  color: inherit;
  cursor: pointer;
  transition:
    border-color 0.15s ease,
    transform 0.15s ease,
    box-shadow 0.15s ease,
    background 0.15s ease;
}

.tutorials-library-hub__card:hover {
  border-color: color-mix(in srgb, var(--color-accent) 45%, var(--color-border));
  transform: translateY(-1px);
  box-shadow: 0 8px 22px color-mix(in srgb, var(--color-text) 8%, transparent);
}

.tutorials-library-hub__card.is-active {
  border-color: var(--color-accent);
  background: color-mix(in srgb, var(--color-accent) 8%, var(--color-surface));
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--color-accent) 25%, transparent);
}

.tutorials-library-hub__card:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}

.tutorials-library-hub__icon {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: var(--radius-sm, 8px);
  background: color-mix(in srgb, var(--color-text) 6%, var(--color-bg));
  color: var(--color-accent);
}

.tutorials-library-hub__icon svg {
  width: 24px;
  height: 24px;
}

.tutorials-library-hub__icon-img {
  width: 28px;
  height: 28px;
  object-fit: contain;
}

.tutorials-library-hub__body {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}

.tutorials-library-hub__card-title {
  font-size: 15px;
  font-weight: 650;
  letter-spacing: -0.02em;
  line-height: 1.25;
  color: var(--color-text);
}

.tutorials-library-hub__hint {
  font-size: 12px;
  line-height: 1.4;
  color: var(--color-text-muted);
}

.tutorials-library-hub__count {
  margin-top: 2px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.01em;
  color: color-mix(in srgb, var(--color-accent) 75%, var(--color-text));
}

.tutorials-library-hub__card--browse-all .tutorials-library-hub__icon {
  background: color-mix(in srgb, var(--color-accent) 12%, var(--color-bg));
}

.tutorials-library-filters[hidden] {
  display: none;
}

.tutorials-library-results__title {
  margin: 0 0 12px;
  font-size: clamp(20px, 2.5vw, 24px);
  font-weight: 650;
  letter-spacing: -0.03em;
  color: var(--color-text);
}

.tutorials-library-results__note {
  margin: -4px 0 14px;
  font-size: 13px;
  line-height: 1.5;
  color: var(--color-text-muted);
}

.page--tutorials-all .tutorials-search-wrap {
  margin-bottom: 12px;
}

/* ── Tag filters (category pages) ─────────────────── */

.tutorials-tag-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 4px 0 12px;
}

.tutorials-category-toolbar {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.tutorials-category-toolbar .tutorials-tag-filters {
  padding-bottom: 12px;
}

.page--tutorials-category .tutorials-category-toolbar {
  margin-top: 4px;
}

.tutorials-tag-filters[hidden] {
  display: none;
}

.tutorials-tag-pill {
  padding: 7px 14px;
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: var(--color-surface);
  color: var(--color-text);
  font: inherit;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: -0.01em;
  line-height: 1.2;
  cursor: pointer;
  transition:
    border-color 0.15s ease,
    background 0.15s ease,
    color 0.15s ease;
}

.tutorials-tag-pill:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
}

.tutorials-tag-pill--active {
  border-color: var(--color-accent);
  background: color-mix(in srgb, var(--color-accent) 10%, var(--color-surface));
  color: var(--color-accent);
}

.tutorials-tag-pill:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}

.tutorials-library-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 24px;
  margin: 4px 0 12px;
  padding: 12px 0 4px;
  border-top: 1px solid color-mix(in srgb, var(--color-border) 70%, transparent);
}

.tutorials-library-toolbar__group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.tutorials-library-toolbar__label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.tutorials-date-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.tutorials-date-pill {
  padding: 7px 14px;
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: var(--color-surface);
  color: var(--color-text);
  font: inherit;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: -0.01em;
  line-height: 1.2;
  cursor: pointer;
  transition:
    border-color 0.15s ease,
    background 0.15s ease,
    color 0.15s ease;
}

.tutorials-date-pill:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
}

.tutorials-date-pill--active {
  border-color: var(--color-accent);
  background: color-mix(in srgb, var(--color-accent) 10%, var(--color-surface));
  color: var(--color-accent);
}

.tutorials-date-pill:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}

.tutorials-library-select,
.tutorials-duration-select {
  min-width: 150px;
  max-width: 100%;
  padding: 7px 32px 7px 14px;
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background:
    var(--color-surface)
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M3 4.5 6 7.5 9 4.5'/%3E%3C/svg%3E")
    no-repeat right 12px center;
  color: var(--color-text);
  font: inherit;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: -0.01em;
  line-height: 1.2;
  cursor: pointer;
  appearance: none;
  transition:
    border-color 0.15s ease,
    background-color 0.15s ease,
    color 0.15s ease;
}

.tutorials-library-select:hover,
.tutorials-library-select:focus,
.tutorials-duration-select:hover,
.tutorials-duration-select:focus {
  border-color: var(--color-accent);
  color: var(--color-accent);
  outline: none;
}

.tutorials-library-select:focus-visible,
.tutorials-duration-select:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}

.tutorials-category-grid {
  margin-top: 4px;
}

.page--tutorials-category .tutorials-blender-topic-sections {
  margin-top: 8px;
}

.page--tutorials-category .tutorials-blender-topic-section + .tutorials-blender-topic-section {
  margin-top: 32px;
  padding-top: 32px;
  border-top: 1px solid color-mix(in srgb, var(--color-border) 75%, transparent);
}

.page--tutorials-category .tutorials-blender-topic-section .tutorials-home-section__header {
  margin-bottom: 16px;
}

.page--tutorials-category .tutorials-category-toolbar[hidden] {
  display: none;
}

.page--tutorials-category .tutorials-blender-topic-browse-wrap[hidden] {
  display: none;
}

.page--tutorials-category .tutorials-blender-topic-browse {
  margin: 20px 0 8px;
}

.page--tutorials-category .tutorials-blender-topic-browse .tutorials-home-section__title {
  margin-bottom: 14px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--color-text-muted) 80%, var(--color-text));
}

.page--tutorials-category .tutorials-browse-grid--blender-topics {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;
}

.page--tutorials-category .tutorials-browse-card--blender-topic {
  padding: 10px 12px;
}

.page--tutorials-category .tutorials-browse-card--blender-topic .tutorials-browse-card__title {
  font-size: 13px;
  line-height: 1.25;
}

.page--tutorials-category .page__header h1 {
  font-size: clamp(26px, 4vw, 32px);
  font-weight: 600;
  letter-spacing: -0.03em;
  margin-bottom: 6px;
  color: var(--color-text);
}

.page--tutorials-category .page__subtitle {
  max-width: 62ch;
  font-size: clamp(14px, 1.8vw, 16px);
  line-height: 1.55;
  color: var(--color-text-muted);
}

.page--tutorials-category .tutorials-page__count {
  font-weight: 600;
}

.tutorials-topic-filters {
  margin: 0 0 14px;
  padding-top: 14px;
  border-top: 1px solid color-mix(in srgb, var(--color-border) 70%, transparent);
}

.tutorials-topic-filters__title {
  margin: 0 0 10px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--color-text-muted) 80%, var(--color-text));
}

.tutorials-topic-filters__more {
  margin: 10px 0 0;
  padding: 0;
  border: 0;
  background: none;
  font: inherit;
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text-muted);
  cursor: pointer;
  transition: color 0.15s ease;
}

.tutorials-topic-filters__more:hover {
  color: var(--color-accent);
}

.tutorials-topic-filters__more:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}

.tutorials-tag-pill__count {
  margin-left: 6px;
  font-size: 11px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: color-mix(in srgb, var(--color-text-muted) 80%, var(--color-text));
}

.tutorials-tag-pill--active .tutorials-tag-pill__count {
  color: color-mix(in srgb, var(--color-accent) 75%, var(--color-text));
}

.tutorials-category-featured {
  margin: 0 0 20px;
}

.tutorials-category-featured[hidden] {
  display: none;
}

.tutorials-featured--category {
  margin-top: 0;
}

.page--tutorials-category .tutorials-category-featured + .tutorials-search-row,
.page--tutorials-category .tutorials-category-featured + .tutorials-search-wrap {
  margin-top: 0;
}

.page--tutorials-category .tutorials-search-row {
  display: grid;
  grid-template-columns: minmax(0, 1.85fr) repeat(3, minmax(0, 0.92fr));
  gap: 8px;
  align-items: stretch;
  width: 100%;
  margin-bottom: 4px;
}

.page--tutorials-category .tutorials-search-row__filters {
  display: contents;
}

.page--tutorials-category .tutorials-search-wrap {
  flex: none;
  width: auto;
  max-width: none;
}

.page--tutorials-category .tutorials-sort {
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

.page--tutorials-category .tutorials-sort__trigger {
  min-width: 0;
  width: 100%;
}

.page--tutorials-category .tutorials-sort[data-filter="duration"] .tutorials-sort__trigger {
  min-width: 0;
}

.page--tutorials-category .tutorials-search {
  min-height: 40px;
}

.page--tutorials-category .tutorials-search__input {
  padding: 9px 0;
  font-size: 14px;
}

.page--tutorials-category .tutorials-sort {
  min-height: 40px;
  padding: 0 8px;
  gap: 6px;
}

.page--tutorials-category .tutorials-sort__label {
  font-size: 12px;
}

.page--tutorials-category .tutorials-sort__trigger {
  padding: 5px 2px 5px 0;
  font-size: 13px;
  gap: 4px;
}

.page--tutorials-category .tutorials-sort__value {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.page--tutorials-category .tutorials-sort__chevron svg {
  width: 12px;
  height: 12px;
}

.tutorials-card__meta--category {
  font-size: 13px;
}

.tutorials-card__meta-topic {
  font-weight: 650;
  color: var(--color-accent);
}

/* ── Categories & cards ───────────────────────────── */

.tutorials-catalog {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.tutorials-catalog--library {
  margin-top: 4px;
}

.tutorials-category--library + .tutorials-category--library {
  padding-top: 28px;
  border-top: 1px solid color-mix(in srgb, var(--color-border) 75%, transparent);
}

.tutorials-category__title {
  margin: 0 0 14px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--color-text-muted) 80%, var(--color-text));
}

.tutorials-search-results__title {
  margin: 0 0 14px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--color-text-muted) 80%, var(--color-text));
}

.tutorials-browse[hidden] {
  display: none;
}

.tutorials-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.tutorials-list__footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px 16px;
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid color-mix(in srgb, var(--color-border) 70%, transparent);
}

.tutorials-list__count {
  margin: 0;
  font-size: 13px;
  font-weight: 500;
  color: var(--color-text-muted);
}

.tutorials-list__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
}

.tutorials-list__load-more {
  padding: 8px 14px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md, 8px);
  background: var(--color-surface);
  color: var(--color-text);
  font: inherit;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: -0.01em;
  cursor: pointer;
  transition:
    border-color 0.15s ease,
    color 0.15s ease,
    background 0.15s ease;
}

.tutorials-list__load-more:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
  background: color-mix(in srgb, var(--color-accent) 6%, var(--color-surface));
}

.tutorials-list__load-all {
  border-color: color-mix(in srgb, var(--color-accent) 35%, var(--color-border));
  background: color-mix(in srgb, var(--color-accent) 8%, var(--color-surface));
}

.tutorials-list__load-all:hover {
  border-color: var(--color-accent);
  background: color-mix(in srgb, var(--color-accent) 14%, var(--color-surface));
  color: var(--color-accent);
}

.tutorials-list__load-more:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}

.tutorials-tag-filters:not([hidden]) {
  display: flex;
}

.tutorials-home-tags {
  display: none;
}

.tutorials-card {
  overflow: hidden;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.04);
  transition:
    border-color 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.tutorials-card:hover {
  border-color: color-mix(in srgb, var(--color-accent) 40%, var(--color-border));
  transform: translateY(-2px);
  box-shadow: 0 8px 22px color-mix(in srgb, var(--color-text) 10%, transparent);
}

.tutorials-card__media {
  aspect-ratio: 16 / 9;
  background: var(--color-text);
}

.tutorials-card__body {
  padding: 10px 12px 12px;
}

.tutorials-card__title {
  margin: 0;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.3;
  color: var(--color-text);
}

.tutorials-card__meta {
  margin: 4px 0 0;
  font-size: 12px;
  font-weight: 500;
  line-height: 1.35;
  color: var(--color-text-muted);
}

.tutorials-card__meta-sep {
  opacity: 0.7;
}

.tutorials-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  min-height: 220px;
  padding: 48px 20px;
}

.tutorials-loading__spinner {
  width: 36px;
  height: 36px;
  border: 3px solid color-mix(in srgb, var(--color-text) 12%, transparent);
  border-top-color: var(--color-text-muted);
  border-radius: 50%;
  animation: tutorials-loading-spin 0.75s linear infinite;
}

@keyframes tutorials-loading-spin {
  to {
    transform: rotate(360deg);
  }
}

.tutorials-loading__text {
  margin: 0;
  font-size: 14px;
  color: var(--color-text-muted);
}

.tutorials-empty {
  padding: 28px 20px;
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--color-text) 2%, var(--color-bg));
  text-align: center;
}

.tutorials-empty p {
  margin: 0;
  font-size: 14px;
  line-height: 1.55;
  color: var(--color-text-muted);
}

.tutorials-empty p + p {
  margin-top: 8px;
}

.tutorials-empty strong,
.tutorials-empty em {
  color: var(--color-text);
  font-style: normal;
  font-weight: 600;
}

.tutorials-card__title-link {
  color: inherit;
  text-decoration: none;
  transition: color 0.15s ease;
}

.tutorials-card__title-link:hover {
  color: var(--color-accent);
}

.tutorials-featured__title-link {
  color: inherit;
  text-decoration: none;
  transition: color 0.15s ease;
}

.tutorials-featured__title-link:hover {
  color: var(--color-accent);
}

/* ── Card thumbnail (links to tutorial page) ──────── */

.tutorials-card__thumb {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
}

.tutorials-card__thumb-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.25s ease;
}

.tutorials-card__thumb-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: color-mix(in srgb, var(--color-text) 0%, transparent);
  opacity: 0;
  transition:
    opacity 0.2s ease,
    background 0.2s ease;
}

.tutorials-card__thumb-label {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: #fff;
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.45);
}

.tutorials-card:hover .tutorials-card__thumb-overlay,
.tutorials-featured:hover .tutorials-card__thumb-overlay,
.tutorials-card__thumb:focus-visible .tutorials-card__thumb-overlay {
  opacity: 1;
  background: color-mix(in srgb, var(--color-text) 48%, transparent);
}

.tutorials-card:hover .tutorials-card__thumb-img,
.tutorials-featured:hover .tutorials-card__thumb-img {
  transform: scale(1.03);
}

.tutorials-card__thumb--featured .tutorials-card__thumb-label {
  font-size: 14px;
}

/* ── Tutorial detail page ───────────────────────── */

.tutorials-detail__header {
  margin-bottom: 18px;
}

.tutorials-detail__title {
  margin: 0;
  font-size: clamp(1.5rem, 2.4vw, 2rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.2;
  color: var(--color-text);
}

.tutorials-detail__player {
  aspect-ratio: 16 / 9;
  margin-bottom: 20px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-text);
  overflow: hidden;
}

.tutorials-detail__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0 10px;
  margin: 0 0 28px;
  padding: 0 0 24px;
  border-bottom: 1px solid color-mix(in srgb, var(--color-border) 75%, transparent);
  font-size: 14px;
  line-height: 1.5;
}

.tutorials-detail__meta-sep {
  color: color-mix(in srgb, var(--color-text-muted) 55%, transparent);
  user-select: none;
}

.tutorials-detail__meta-text {
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--color-text);
}

.tutorials-detail__meta-text.is-muted {
  font-weight: 500;
  color: var(--color-text-muted);
}

.tutorials-detail__meta-link {
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--color-text);
  text-decoration: none;
  transition: color 0.15s ease;
}

.tutorials-detail__meta-link:hover {
  color: var(--color-accent);
}

.tutorials-detail__description {
  margin-bottom: 8px;
}

.tutorials-detail__section-title {
  margin: 0 0 10px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--color-text-muted) 80%, var(--color-text));
}

.tutorials-detail__description p {
  margin: 0 0 10px;
  font-size: 15px;
  line-height: 1.65;
  color: var(--color-text-muted);
}

.tutorials-detail__description p:last-child {
  margin-bottom: 0;
}

.tutorials-home-section--related {
  margin-top: 28px;
}

/* ── Embedded video player ────────────────────────── */

.tutorials-video {
  position: relative;
  overflow: hidden;
}

.tutorials-video iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

@media (max-width: 1100px) {
  .page--tutorials-category .tutorials-browse-grid--blender-topics {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  .tutorials-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .tutorials-browse-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .page--tutorials-category .tutorials-browse-grid--blender-topics {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .tutorials-library-hub__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .tutorials-featured {
    grid-template-columns: 1fr;
  }

  .tutorials-featured__media {
    order: -1;
  }

  .tutorials-grid {
    grid-template-columns: 1fr;
  }

  .tutorials-browse-grid {
    grid-template-columns: 1fr;
  }

  .page--tutorials-category .tutorials-browse-grid--blender-topics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .page--tutorials {
    padding: 24px 16px 40px;
  }

  .tutorials-library-hub {
    padding: 14px;
  }

  .tutorials-library-hub__grid {
    grid-template-columns: 1fr;
  }

  .tutorials-page__intro {
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
  }

  .tutorials-page__meta {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }

  .tutorials-page__count {
    text-align: left;
  }

  .tutorials-featured__body {
    padding: 20px 18px;
  }
}

@media (max-width: 900px) {
  .page--tutorials-category .tutorials-search-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-template-rows: auto auto;
  }

  .page--tutorials-category .tutorials-search-wrap {
    grid-column: 1 / -1;
  }
}

@media (max-width: 560px) {
  .page--tutorials-category .tutorials-search-row {
    display: flex;
    flex-direction: column;
  }

  .page--tutorials-category .tutorials-search-row__filters {
    display: flex;
    flex-direction: column;
    width: 100%;
    gap: 10px;
  }

  .tutorials-sort {
    width: 100%;
    box-sizing: border-box;
  }

  .tutorials-sort__trigger {
    flex: 1;
  }

  .tutorials-sort__menu {
    left: 0;
    right: 0;
    min-width: 0;
  }
}
