/* Theme tokens live in theme.css */

* { box-sizing: border-box; }

html {
  overflow-x: clip;
  max-width: 100%;
}

body {
  margin: 0;
  font-family: var(--font);
  color: var(--text);
  background: var(--bg);
  line-height: 1.55;
  overflow-x: clip;
  max-width: 100%;
}

.app-page a:hover { opacity: 1; }

a { color: inherit; text-decoration: none; }
a:hover { opacity: 0.75; }

/* ── Nav (matches landing header) ── */
.nav-theme-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: 50%;
  background: var(--bg);
  color: var(--text-muted);
  cursor: pointer;
  font: inherit;
  flex-shrink: 0;
}

.nav-theme-toggle:hover {
  color: var(--text);
  border-color: var(--border-hover);
  opacity: 1;
}

.nav-theme-toggle__icon {
  display: block;
}

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

[data-theme="light"] .nav-theme-toggle__icon--sun {
  display: none;
}

[data-theme="light"] .nav-theme-toggle__icon--moon {
  display: block;
}

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 28px var(--page-pad);
  border-bottom: 1px solid var(--border);
  background: var(--bg);
  position: sticky;
  top: 0;
  z-index: 20;
  max-width: 100%;
  isolation: isolate;
}

.logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  opacity: 1;
  padding: 10px 14px;
  margin: -10px -14px;
}

.logo:hover {
  opacity: 0.85;
}

.logo__text {
  display: block;
  font-family: var(--font);
  font-size: 2rem;
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--text);
}

.nav-center {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2rem;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  min-width: 0;
}

.nav-center__link {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-muted);
  opacity: 1;
  white-space: nowrap;
}

.nav-center__link:hover,
.nav-center__link.is-active {
  color: var(--text);
}

.nav-end {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-shrink: 0;
  gap: 12px;
}

.nav-end__link {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-muted);
  white-space: nowrap;
}

.nav-end__link:hover { color: var(--text); }

.nav-login-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 22px;
  border: 1px solid var(--border-strong);
  color: var(--text);
  font-family: inherit;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  white-space: nowrap;
}

.nav-login-btn:hover {
  border-color: var(--border-focus);
  color: var(--text);
  opacity: 1;
}

.nav-apply-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 88px;
  padding: 14px 22px;
  background: var(--accent);
  color: var(--accent-fg);
  font-family: inherit;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  white-space: nowrap;
}

.nav-apply-btn:hover {
  background: var(--accent-hover);
  color: var(--accent-fg);
  opacity: 1;
}

.nav-profile {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  overflow: visible;
  border: 1px solid var(--border);
  background: var(--bg);
  flex-shrink: 0;
  opacity: 1;
}

.nav-profile.is-active {
  border-color: var(--text);
}

.nav-profile__avatar {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  overflow: hidden;
}

.nav-profile__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.nav-profile__avatar > span {
  font-size: 0.95rem;
  font-weight: 700;
}

.nav-messages {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--text-muted);
  flex-shrink: 0;
  opacity: 1;
  overflow: visible;
}

.nav-messages:hover,
.nav-messages.is-active,
.nav-messages--notify {
  border-color: var(--text);
  color: var(--text);
}

.nav-messages__icon {
  display: block;
}

.nav-notifications {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--text-muted);
  flex-shrink: 0;
  opacity: 1;
  overflow: visible;
}

.nav-notifications:hover,
.nav-notifications.is-active,
.nav-notifications--notify {
  border-color: var(--text);
  color: var(--text);
}

.nav-notifications__icon {
  display: block;
}

.nav-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  color: var(--text);
  cursor: pointer;
  flex-shrink: 0;
}

.nav-toggle:hover {
  opacity: 0.75;
}

.nav-toggle__lines {
  display: grid;
  gap: 5px;
  width: 18px;
}

.nav-toggle__lines span {
  display: block;
  height: 2px;
  background: currentColor;
  transition: transform 0.2s ease, opacity 0.2s ease;
}

.nav.is-open .nav-toggle__lines span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.nav.is-open .nav-toggle__lines span:nth-child(2) {
  opacity: 0;
}

.nav.is-open .nav-toggle__lines span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

.nav-menu {
  display: flex;
  flex: 1;
  align-items: center;
  justify-content: flex-end;
  gap: 2rem;
  min-width: 0;
}

body.nav-menu-open {
  overflow: hidden;
  overscroll-behavior: none;
}

/* ── Buttons ── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 22px;
  border-radius: 0;
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border: 1px solid transparent;
  cursor: pointer;
  font: inherit;
}

.btn--primary {
  background: var(--accent);
  color: var(--accent-fg);
}
.btn--primary:hover {
  background: var(--accent-hover);
  color: var(--accent-fg);
  opacity: 1;
}
.btn--primary:disabled,
.btn--primary[aria-disabled="true"] {
  opacity: 0.45;
  cursor: not-allowed;
  pointer-events: none;
}
.upload-size-status {
  margin: 0 0 0.75rem;
  font-size: 0.9rem;
  color: #f87171;
}

.media-upload-section__error {
  margin: 0.5rem 0 0;
  font-size: 0.9rem;
  font-weight: 600;
  color: #f87171;
}

.media-upload-section__error[hidden] {
  display: none !important;
}
.btn--ghost {
  border-color: var(--border);
  background: transparent;
  color: var(--text);
}
.btn--ghost:hover {
  border-color: var(--border-hover);
  opacity: 1;
}
.btn--danger {
  background: transparent;
  color: #ff8a8a;
  border-color: rgba(255, 100, 100, 0.55);
}

.btn--danger:hover {
  background: rgba(255, 100, 100, 0.08);
  border-color: #ff8a8a;
  opacity: 1;
}

.btn--danger-outline {
  background: transparent;
  color: #ff6b6b;
  border: 1px solid rgba(255, 100, 100, 0.55);
}

.btn--danger-outline:hover {
  background: rgba(255, 100, 100, 0.08);
  color: #ff8a8a;
  border-color: #ff8a8a;
  opacity: 1;
}

/* ── Page blocks (full bleed) ── */
.hero,
.page-header,
.form-page,
.auth-card,
.profile-hero,
.project-detail__header-wrap,
.section__head-bar {
  max-width: none;
  margin: 0;
  padding: var(--page-pad);
  border-bottom: 1px solid var(--border);
}

.hero h1,
.page-header h1,
.form-page h1,
.auth-card h1,
.profile-hero__name-row h1,
.project-detail__title-row h1 {
  font-family: var(--font);
  font-weight: 800;
  line-height: 0.95;
  letter-spacing: -0.03em;
  margin: 0.3rem 0 0;
}

/* Upload work — align with project detail page gutters */
.form-page.form-page--detail-pad {
  --detail-pad-inline: calc(var(--page-pad) * 3);
  --detail-pad-block: calc(var(--page-pad) * 1.5);
  padding-block: var(--detail-pad-block);
  padding-inline: var(--detail-pad-inline);
}

.create-form__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}

.create-draft-status {
  margin: 0.5rem 0 0;
  color: var(--text-muted);
}

.leave-draft-modal__actions {
  flex-wrap: wrap;
}

.leave-draft-modal__actions .btn {
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.72rem;
}

.notifications-page .page-header h1,
.messages-page .page-header h1,
.profile-panel[data-profile-panel="messages"] .page-header h1 {
  font-size: clamp(1.5rem, 3vw, 2rem);
}

.hero--app h1 {
  font-size: clamp(2rem, 5vw, 3.5rem);
  max-width: 16ch;
}

.eyebrow {
  font-family: "Syne Mono", ui-monospace, monospace;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 11px;
  color: var(--text-muted);
  margin: 0;
}

.eyebrow .explore-filter-link {
  color: var(--text-muted);
  text-decoration: none;
}

.eyebrow .explore-filter-link:hover {
  color: var(--text);
}

.page-header__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}

.page-header__top h1 {
  margin: 0.3rem 0 0;
}

.page-header__top .btn {
  flex-shrink: 0;
  margin-top: 0.15rem;
}

.page-header__lead {
  margin: 0.5rem 0 0;
  color: var(--text-muted);
}

.error-page__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 1.25rem;
}

.section {
  max-width: none;
  margin: 0;
  padding: 0;
  border-bottom: 1px solid var(--border);
}

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

.section__head-bar {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin: 0;
  padding: 1.25rem var(--page-pad);
  border-bottom: 1px solid var(--border);
}

.section__head-bar h2 {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 700;
}

.section__head-bar a {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
}

.section__head-bar a:hover { color: var(--text); }

.explore-work__count {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.project-card--highlight {
  box-shadow: inset 0 0 0 2px var(--highlight-ring);
  background: var(--surface-hover-strong);
}

.explore-work__empty {
  margin: 0;
  padding: var(--page-pad);
}

.explore-creatives + .explore-work {
  border-top: none;
}

/* ── Grids (flush tiles, landing-style) ── */
.grid {
  display: grid;
  gap: 0;
  margin: 0;
  padding: 0;
  max-width: 100%;
  border-left: 1px solid var(--border);
}

.grid--projects {
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  align-items: stretch;
}

.grid--projects > .project-card {
  min-width: 0;
  height: 100%;
}

.project-edit__delete-form {
  display: inline-block;
  margin: 0;
}

.project-delete-modal__title,
.job-delete-modal__title {
  margin: 0;
  padding: 0.85rem 1.25rem 1rem;
  border-bottom: 1px solid var(--border);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.35;
  color: var(--text);
  letter-spacing: -0.01em;
}

.project-delete-modal__title[hidden],
.job-delete-modal__title[hidden] {
  display: none;
}

.project-delete-modal .media-modal__hint {
  border-bottom: none;
  padding-bottom: 0.65rem;
}

.project-delete-modal:has([data-project-delete-title][hidden]) .media-modal__hint {
  border-bottom: 1px solid var(--border);
  padding-bottom: 1rem;
}

.project-delete-modal .media-modal__error {
  border-bottom: 1px solid var(--border);
}

.project-delete-modal .media-modal__error[hidden] {
  display: none;
}

.grid--users {
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}

.project-card {
  display: block;
  margin: 0;
  background: var(--bg);
  border: none;
  border-right: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  border-radius: 0;
  box-shadow: none;
  overflow: hidden;
}

.project-card:hover {
  background: var(--surface-hover);
  transform: none;
  opacity: 1;
  color: inherit;
}

.project-card__media {
  position: relative;
  aspect-ratio: 4/3;
  background: var(--bg-elevated);
  overflow: hidden;
}

.project-card__staffpick {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  z-index: 1;
  padding: 0.3rem 0.45rem;
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1;
  color: var(--accent-fg);
  background: var(--accent);
  pointer-events: none;
}

.project-card--draft {
  opacity: 0.52;
}

.project-card--draft:hover {
  opacity: 0.68;
}

.project-card__draft-label {
  font-family: "Syne Mono", ui-monospace, monospace;
  font-size: 0.72em;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--text-muted);
  text-transform: none;
}

.project-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.project-card__placeholder {
  display: grid;
  place-items: center;
  height: 100%;
  font-weight: 800;
  color: var(--text-muted);
}

.project-card--add .project-card__add-media {
  display: grid;
  place-items: center;
  border: 1px dashed var(--border-strong);
  background: var(--bg);
}

.project-card--more .project-card__add-media {
  display: grid;
  place-items: center;
  border: none;
  background: var(--bg-elevated);
}

.project-card--add:hover .project-card__add-media {
  border-color: var(--border-hover);
  background: var(--surface-hover);
}

.project-card--more:hover .project-card__add-media {
  background: var(--surface-hover);
}

.project-card__add-label {
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--text);
  text-align: center;
  padding: 1rem;
}

.project-card__add-hint {
  color: var(--text-muted);
}

.project-card__meta {
  padding: 1rem 1.25rem 1.25rem;
  border-top: 1px solid var(--border);
}

.project-card__meta h3 {
  margin: 0 0 0.25rem;
  font-size: 1rem;
  font-weight: 600;
}

.project-card__meta p {
  margin: 0;
  font-size: 0.85rem;
  color: var(--text-muted);
}

.project-card__byline {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  overflow: hidden;
  line-height: 1.4;
  max-height: 2.8em;
}

.user-card {
  position: relative;
  display: flex;
  gap: 1rem;
  align-items: center;
  margin: 0;
  padding: 1.25rem;
  background: var(--bg);
  border: none;
  border-right: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  border-radius: 0;
  min-height: 100px;
}

.user-card__badges {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.35rem;
  max-width: calc(100% - 1rem);
}

.user-card__featured {
  max-width: 100%;
  padding: 0.28rem 0.45rem;
  font-size: 0.5rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.2;
  text-align: right;
  text-transform: uppercase;
  color: var(--accent-fg);
  background: var(--accent);
  border: 1px solid var(--border-strong);
}

.user-card:hover {
  background: var(--surface-hover);
  opacity: 1;
}

.user-card__avatar {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  overflow: hidden;
  background: var(--avatar-placeholder-bg);
  border: 1px solid var(--border);
  display: grid;
  place-items: center;
  font-weight: 700;
  flex-shrink: 0;
}

.user-card__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.user-card h3 { margin: 0; font-size: 1rem; font-weight: 600; }
.user-card p { margin: 0.2rem 0 0; font-size: 0.85rem; color: var(--text-muted); }

.user-card--more .user-card__avatar--more {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--text-muted);
  background: var(--bg-elevated);
}

.user-card--more:hover .user-card__avatar--more {
  border-color: var(--text-muted);
  background: var(--surface-hover);
}

/* ── Filters & forms (landing-style) ── */
.filters {
  display: grid;
  grid-template-columns: 2fr repeat(3, 1fr) auto;
  gap: 1px;
  margin: 1.5rem 0 0;
  border: 1px solid var(--border);
  background: var(--border);
}

.filters--jobs {
  grid-template-columns: 2fr 1fr 1fr auto;
}

.filters > * {
  margin: 0;
  border: none;
  position: relative;
  background: var(--bg);
}

.filters input,
.filters select {
  width: 100%;
  padding: 1rem 1.25rem;
  border: none;
  border-radius: 0;
  font: inherit;
  background-color: var(--bg);
  color: var(--text);
}

.filters select {
  padding-right: 2.75rem;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888888' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1.25rem center;
  background-size: 12px;
}

.filters button {
  height: 100%;
  min-height: 52px;
  border: none;
  border-radius: 0;
}

.filters .btn--primary {
  background: var(--accent-hover);
  color: var(--accent-fg);
}

.filters .btn--primary:hover {
  background: var(--accent);
  color: var(--accent-fg);
  opacity: 1;
}

.form input,
.form textarea,
.form select {
  width: 100%;
  padding: 1rem 1.25rem;
  border: none;
  border-radius: 0;
  font: inherit;
  background: var(--bg);
  color: var(--text);
}

textarea {
  resize: vertical;
  max-width: 100%;
  min-width: 0;
}

.form {
  display: grid;
  gap: 0;
  border: 1px solid var(--border);
}

.form > label:not(.profile-avatar-upload__control):not(.project-thumbnail-upload__control) {
  display: grid;
  gap: 0.5rem;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--border);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.form > label:not(.profile-avatar-upload__control):not(.project-thumbnail-upload__control) input,
.form > label:not(.profile-avatar-upload__control):not(.project-thumbnail-upload__control) textarea,
.form > label:not(.profile-avatar-upload__control):not(.project-thumbnail-upload__control) select {
  padding: 0;
  border: none;
  background: transparent;
  color: var(--text);
  font-size: 1rem;
  font-weight: 400;
  text-transform: none;
  letter-spacing: normal;
}

.form--grid {
  grid-template-columns: 1fr 1fr;
}

.form--grid label:nth-child(odd) {
  border-right: 1px solid var(--border);
}

.form--grid button {
  grid-column: 1 / -1;
  margin: 0;
  border-top: 1px solid var(--border);
}

.form--grid > label.form__full {
  grid-column: 1 / -1;
  border-right: none;
}

.form-field__hint {
  display: block;
  margin-top: 0.35rem;
  font-size: 0.85rem;
  font-weight: 400;
  text-transform: none;
  letter-spacing: normal;
  color: var(--text-muted);
}

.form-disciplines {
  margin: 0;
  padding: 1rem 1.25rem;
  border: none;
  border-bottom: 1px solid var(--border);
}

.form-disciplines legend {
  padding: 0;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.form-disciplines__hint {
  font-weight: 500;
  text-transform: none;
  letter-spacing: normal;
  color: var(--text-subtle);
}

.form-disciplines__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 0.65rem 1rem;
  margin-top: 0.85rem;
}

.form-discipline-check {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  margin: 0;
  padding: 0;
  border: none;
  font-size: 0.9rem;
  font-weight: 400;
  letter-spacing: normal;
  text-transform: none;
  color: var(--text);
  cursor: pointer;
}

.form-discipline-check input {
  width: 16px;
  height: 16px;
  margin: 0;
  accent-color: var(--text);
  flex-shrink: 0;
}

/* Upload work — full-bleed outlined discipline grid */
.form-disciplines--bleed {
  padding: 0;
}

.form-disciplines--bleed legend {
  display: block;
  width: 100%;
  padding: 1rem 1.25rem 0;
  margin: 0 0 1rem;
  box-sizing: border-box;
}

.form-disciplines--bleed .form-disciplines__grid {
  margin-top: 0;
  gap: 0;
  border-top: 1px solid var(--border);
  border-left: 1px solid var(--border);
  grid-template-columns: repeat(4, 1fr);
}

.form-disciplines--bleed .form-discipline-check {
  margin: 0;
  padding: 1rem 1.25rem;
  border: none;
  border-right: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  min-height: 3.25rem;
}

.form-disciplines--bleed .form-discipline-check:hover {
  background: var(--surface-hover);
}

.form-disciplines--bleed .form-discipline-check:has(input:checked) {
  background: var(--surface-hover-strong);
}

/* Home feed — discipline filter grid */
.discipline-filter {
  border-bottom: 1px solid var(--border);
}

.discipline-filter__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  max-width: 100%;
  border: 1px solid var(--border);
  background: var(--bg);
}

.discipline-filter__cell {
  display: flex;
  align-items: center;
  min-height: 3.25rem;
  padding: 1rem 1.25rem;
  border: none;
  border-right: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background: var(--bg);
  color: var(--text);
  font-size: 0.9rem;
  font-weight: 500;
  line-height: 1.3;
  text-decoration: none;
}

.discipline-filter__cell:nth-child(4n) {
  border-right: none;
}

.discipline-filter__cell:hover {
  background: var(--bg-elevated);
}

.discipline-filter__cell.is-active {
  background: var(--accent);
  color: var(--accent-fg);
}

.hero--app__filter-note {
  margin: 0.75rem 0 0;
  font-size: 0.9rem;
  color: var(--text-muted);
}

.hero--app__filter-note a {
  color: var(--text);
}

.discover-feed__spaced-section {
  margin-top: 2rem;
}

@media (max-width: 800px) {
  .discover-feed__spaced-section {
    margin-top: 1.25rem;
  }
}

.tabs {
  display: flex;
  gap: 0;
  margin: 1.5rem 0 0;
  border: 1px solid var(--border);
}

.tabs a {
  flex: 1;
  padding: 1rem 1.25rem;
  text-align: center;
  border-right: 1px solid var(--border);
  border-bottom: none;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.tabs a:last-child { border-right: none; }

.tabs a.active {
  color: var(--text);
  background: var(--surface-hover-strong);
}

.tabs a:hover { color: var(--text); opacity: 1; }

/* ── Profile ── */
.profile-avatar-upload {
  display: flex;
  justify-content: flex-start;
  padding: 1.25rem var(--page-pad);
  margin: 0;
}

.profile-avatar-upload__control {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
  width: 120px;
  margin: 0;
  padding: 0;
  border: none;
  border-bottom: none;
  background: none;
  cursor: pointer;
  font: inherit;
  font-weight: inherit;
  letter-spacing: normal;
  text-transform: none;
  color: inherit;
  text-align: center;
}

.profile-avatar-upload__input {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.profile-avatar-upload__circle {
  display: grid;
  place-items: center;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--avatar-placeholder-bg);
  color: var(--text);
  transition: border-color 0.15s ease;
}

.profile-avatar-upload__control:hover .profile-avatar-upload__circle {
  border-color: var(--text);
}

.profile-avatar-upload__circle img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.profile-avatar-upload__initial {
  font-size: 2.5rem;
  font-weight: 800;
  line-height: 1;
}

.profile-avatar-upload__hint {
  display: block;
  width: 100%;
  margin: 0;
  text-align: center;
}

.project-thumbnail-upload {
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--border);
}

.project-thumbnail-upload__title {
  margin: 0 0 0.35rem;
}

.project-thumbnail-upload__lead {
  margin: 0 0 1rem;
  font-size: 0.9rem;
  color: var(--text-muted);
  text-transform: none;
  letter-spacing: normal;
  font-weight: 400;
}

.project-thumbnail-upload__control {
  display: block;
  position: relative;
  width: min(100%, 280px);
  margin: 0;
  padding: 0;
  border: none;
  background: none;
  cursor: pointer;
  font: inherit;
  color: inherit;
}

.project-thumbnail-upload__input {
  position: absolute;
  inset: 0;
  z-index: 2;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  border: 0;
  opacity: 0;
  cursor: pointer;
}

.project-thumbnail-upload__frame {
  position: relative;
  display: grid;
  place-items: center;
  width: 100%;
  aspect-ratio: 4 / 3;
  border: 1px solid var(--border);
  background: var(--bg-elevated);
  overflow: hidden;
  transition: border-color 0.15s ease;
  pointer-events: none;
}

.project-thumbnail-upload__control:hover .project-thumbnail-upload__frame {
  border-color: var(--text);
}

.project-thumbnail-upload__frame img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.project-thumbnail-upload__placeholder {
  font-size: 2.5rem;
  font-weight: 300;
  line-height: 1;
  color: var(--text-faint);
}

.project-thumbnail-upload__hint {
  margin: 0.65rem 0 0;
  pointer-events: none;
}

.profile-hero {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 2rem;
  align-items: start;
}

.profile-hero__avatar {
  width: 160px;
  height: 160px;
  border-radius: 50%;
  overflow: hidden;
  background: var(--avatar-placeholder-bg);
  border: 1px solid var(--border);
  display: grid;
  place-items: center;
  font-size: 3rem;
  font-weight: 800;
}

.profile-hero__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.profile-hero__meta {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.profile-hero__meta .eyebrow {
  flex: 1 1 auto;
  min-width: 0;
  max-width: 100%;
  white-space: normal;
  line-height: 1.45;
}

.profile-hero__actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0;
}

.profile-hero__action {
  flex-shrink: 0;
  font-family: "Syne Mono", ui-monospace, monospace;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  opacity: 1;
  white-space: nowrap;
}

.profile-hero__action:hover,
.profile-hero__action.is-active {
  color: var(--text);
}

.profile-hero__name-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin: 0.2rem 0;
}

.profile-hero__name-row h1 {
  font-size: clamp(2rem, 4vw, 3rem);
  margin: 0;
}

.profile-hero__edit-btn {
  flex-shrink: 0;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text-muted);
  display: grid;
  place-items: center;
  padding: 0;
  cursor: pointer;
  text-decoration: none;
  transition: color 0.15s ease, border-color 0.15s ease;
}

.profile-hero__edit-btn:hover,
.profile-hero__edit-btn.is-active {
  color: var(--text);
  border-color: var(--text);
}

.profile-hero__edit-btn svg {
  display: block;
}

.profile-bio {
  max-width: 50ch;
  color: var(--text-muted);
  white-space: pre-line;
}
.profile-links {
  display: flex;
  gap: 0.65rem;
  margin: 0.75rem 0;
  flex-wrap: wrap;
}

.profile-links__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border: 1px solid var(--border);
  border-radius: 50%;
  color: var(--text-muted);
  text-decoration: none;
  transition: color 0.15s ease, border-color 0.15s ease, background 0.15s ease;
}

.profile-links__link:hover {
  color: var(--text);
  border-color: var(--border-hover);
  background: var(--surface-hover-strong);
}

.profile-links__icon {
  display: block;
  flex-shrink: 0;
}

.profile-links__icon--linkedin {
  width: 18px;
  height: 18px;
  object-fit: contain;
}
.profile-actions,
.profile-tabs {
  display: flex;
  flex-wrap: nowrap;
  gap: 0;
  margin: 0;
  width: 100%;
  border-bottom: 1px solid var(--border);
}

.profile-actions .btn,
.profile-tab {
  flex: 1 1 0;
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem 0.75rem;
  border-radius: 0;
  border: none;
  border-right: 1px solid var(--border);
  font-family: inherit;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  cursor: pointer;
  background: var(--bg);
  color: var(--text-muted);
  text-decoration: none;
  position: relative;
}

.profile-actions .btn:last-child,
.profile-tab:last-child {
  border-right: none;
}

.profile-tab.is-active {
  color: var(--text);
  background: var(--surface-hover-strong);
}

.profile-tab:hover {
  color: var(--text);
  opacity: 1;
  background: var(--surface-hover);
}

.profile-tab--link {
  color: var(--text-muted);
}

.profile-tab__badge {
  position: absolute;
  top: 6px;
  right: 6px;
}

.profile-actions .btn--ghost {
  background: var(--bg);
}

.profile-actions .btn--ghost:hover {
  background: var(--surface-hover);
}

.profile-actions .btn--primary:hover {
  background: var(--accent-hover);
  color: var(--accent-fg);
  opacity: 1;
}

.profile-actions form {
  flex: 1 1 0;
  min-width: 0;
  margin: 0;
  display: flex;
  border-right: 1px solid var(--border);
}

.profile-actions form [data-profile-follow-btn] {
  width: 100%;
  border-right: none;
}

.profile-hero__stat {
  margin: 0.35rem 0 0;
  font-size: 0.9rem;
  color: var(--text-muted);
}

.profile-hero__stat-sep {
  margin: 0 0.35rem;
}

.profile-hero__stat-link {
  color: inherit;
  text-decoration: none;
}

.profile-hero__stat-link:hover {
  color: var(--text);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.follow-list {
  border-top: 1px solid var(--border);
}

.profile-panels {
  border-bottom: 1px solid var(--border);
}

.profile-panel[hidden] {
  display: none !important;
}

.profile-panel__section {
  margin: 0;
  padding: 0;
  border-bottom: none;
}

.profile-edit-page__back {
  margin: 0;
  padding: 1rem var(--page-pad);
  border-bottom: 1px solid var(--border);
}

.profile-edit-page__back a {
  color: var(--text-muted);
}

.profile-edit-page__back a:hover {
  color: var(--text);
}

.profile-edit-page .profile-panel__section--form {
  width: 50%;
  max-width: 100%;
  margin: 2rem auto;
  border: 1px solid var(--border);
}

@media (max-width: 768px) {
  .profile-edit-page .profile-panel__section--form {
    width: 100%;
  }
}

.profile-panel[data-profile-panel="messages"] .profile-panel__section .empty {
  margin: 0;
  padding: var(--page-pad);
  border-bottom: none;
}

.profile-panel__section .portfolio-section__head {
  margin: 0;
  padding: 1.25rem var(--page-pad);
  border-bottom: 1px solid var(--border);
  font-size: 1.25rem;
}

.profile-edit-avatar-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1.5rem;
  border-bottom: 1px solid var(--border);
}

.profile-edit-avatar-row .profile-avatar-upload {
  padding: 1.25rem var(--page-pad);
  padding-right: 0;
  flex: 0 0 auto;
}

.profile-edit-avatar-row__delete {
  flex-shrink: 0;
  margin: 1.25rem var(--page-pad) 0 0;
  width: auto;
}

.profile-panel__lead {
  margin: 2.5rem 0 0;
  padding: 0 var(--page-pad) 1rem;
  color: var(--text-muted);
}

.profile-panel__section--form .form {
  margin: 0;
  border: none;
}

.profile-panel__section--form .form > label:not(.profile-avatar-upload__control):not(.project-thumbnail-upload__control) {
  padding: 1rem var(--page-pad);
}

.profile-panel__section--form .form .btn:not(.profile-edit-avatar-row__delete) {
  width: 100%;
  margin: 0;
  border: none;
  border-top: 1px solid var(--border);
  border-radius: 0;
}

.btn--has-badge {
  position: relative;
  overflow: visible;
}

.btn__badge {
  position: absolute;
  top: -4px;
  right: -4px;
  width: 11px;
  height: 11px;
  background: var(--accent);
  border: 2px solid var(--text);
  border-radius: 50%;
  pointer-events: none;
  z-index: 2;
}

.portfolio-section {
  border-bottom: 1px solid var(--border);
}

.portfolio-section__head {
  padding: 1.25rem var(--page-pad);
  border-bottom: 1px solid var(--border);
  margin: 0;
  font-size: 1.25rem;
  font-weight: 700;
}

.badge {
  font-size: 0.65rem;
  padding: 0.25rem 0.5rem;
  border-radius: 0;
  background: var(--bg);
  border: 1px solid var(--border);
  vertical-align: middle;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.badge--gold {
  border-color: var(--border-strong);
}

/* ── Project detail ── */
.project-detail {
  max-width: none;
  margin: 0;
  padding: 0;
  --detail-pad-inline: calc(var(--page-pad) * 3);
  --detail-pad-block: calc(var(--page-pad) * 1.5);
}

.project-detail__header-wrap {
  padding-block: var(--detail-pad-block);
  padding-inline: var(--detail-pad-inline);
}

#like,
#comments,
.comment-item {
  scroll-margin-top: 88px;
}

.comment-item {
  transition: background 0.8s ease, box-shadow 0.8s ease;
}

.comment-item--highlight {
  background: var(--surface-hover);
  box-shadow: inset 3px 0 0 var(--border-focus);
}

.project-detail__draft-header,
.project-detail__staffpick-header {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.65rem 1rem;
  margin-top: 0.85rem;
}

.project-detail__draft-badge {
  display: inline-block;
  padding: 0.45rem 0.7rem;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  line-height: 1;
  text-transform: uppercase;
  color: var(--accent-fg);
  background: var(--border-hover);
}

.project-detail__draft-lead {
  margin: 0;
  font-size: 0.9rem;
  color: var(--text-muted);
}

.project-detail__staffpick {
  display: inline-block;
  padding: 0.45rem 0.7rem;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  line-height: 1;
  color: var(--accent-fg);
  background: var(--accent);
}

.project-detail__staffpick-lead {
  margin: 0;
  font-size: 0.9rem;
  color: var(--text-muted);
}

.project-detail--staffpick .project-detail__header-wrap {
  background: linear-gradient(
    180deg,
    var(--surface-hover) 0%,
    transparent 100%
  );
}

.project-detail__header {
  display: grid;
  grid-template-columns: minmax(200px, 300px) minmax(0, 1fr);
  gap: 2rem;
  align-items: start;
}

.project-detail__thumb {
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
}

.project-detail__thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.project-detail__header-main {
  min-width: 0;
}

.project-detail__byline-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin: 0 0 0.15rem;
}

.project-detail__posted {
  flex-shrink: 0;
  margin: 0;
  text-align: right;
  white-space: nowrap;
}

.project-detail__byline {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.5rem;
  flex-wrap: wrap;
  row-gap: 0.35rem;
  min-width: 0;
  margin: 0;
  text-align: left;
}

.project-detail__byline-avatar {
  display: inline-flex;
  flex-shrink: 0;
  text-decoration: none;
}

.project-detail__byline-avatar:hover .user-avatar {
  border-color: var(--text);
}

.project-detail__byline-text {
  flex: 1 1 auto;
  min-width: 0;
  max-width: 100%;
  text-align: left;
  white-space: normal;
  line-height: 1.45;
}

.project-detail__byline-text a {
  color: var(--text);
}

.project-detail__byline-text a:hover {
  color: var(--text-muted);
}

.project-detail__byline-text .explore-filter-link {
  color: var(--text);
  text-decoration: none;
}

.project-detail__byline-text .explore-filter-link:hover {
  color: var(--text-muted);
}

.project-detail__title-row h1 {
  font-size: clamp(1.75rem, 4vw, 2.75rem);
}

.project-detail__actions {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  flex-shrink: 0;
  white-space: nowrap;
  margin-left: auto;
}

.project-detail__actions form {
  margin: 0;
}

.project-detail__audio {
  padding: var(--page-pad);
  border-bottom: 1px solid var(--border);
  background: var(--bg);
}

.project-detail__audio-label {
  margin: 0 0 1rem;
}

.project-detail__audio .waveform-player {
  max-width: 640px;
}

.project-detail__video {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
}

.project-detail__audio + .project-detail__video,
.project-detail__audio + .project-detail__gallery {
  border-top: none;
}

.project-detail__video iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
}

.project-detail__gallery {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: auto;
  gap: 0;
  border-top: 1px solid var(--border);
  border-left: 1px solid var(--border);
}

.project-detail__video + .project-detail__gallery {
  border-top: none;
}

.project-detail__audio + .project-detail__video + .project-detail__gallery {
  border-top: none;
}

.project-detail__gallery + .project-detail__gallery {
  border-top: none;
}

.project-detail__gallery-cell {
  margin: 0;
  position: relative;
  overflow: hidden;
  width: 100%;
  aspect-ratio: 16 / 9;
  border-right: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background: var(--bg);
}

.project-detail__gallery-cell img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  border: none;
  border-radius: 0;
}

/* Mosaic: hero + feature (50% width) + 2×2 on the right */
.project-detail__gallery--count-6 {
  grid-template-columns: repeat(4, 1fr);
}

.project-detail__gallery--count-6 .project-detail__gallery-cell:nth-child(1) {
  grid-column: 1 / -1;
  grid-row: 1;
}

.project-detail__gallery--count-6 .project-detail__gallery-cell:nth-child(2) {
  grid-column: 1 / span 2;
  grid-row: 2 / span 2;
  aspect-ratio: auto;
}

.project-detail__gallery--count-6 .project-detail__gallery-cell:nth-child(3) {
  grid-column: 3;
  grid-row: 2;
}

.project-detail__gallery--count-6 .project-detail__gallery-cell:nth-child(4) {
  grid-column: 4;
  grid-row: 2;
}

.project-detail__gallery--count-6 .project-detail__gallery-cell:nth-child(5) {
  grid-column: 3;
  grid-row: 3;
}

.project-detail__gallery--count-6 .project-detail__gallery-cell:nth-child(6) {
  grid-column: 4;
  grid-row: 3;
}

.project-detail__gallery--count-5 {
  grid-template-columns: repeat(4, 1fr);
}

.project-detail__gallery--count-5 .project-detail__gallery-cell:nth-child(1) {
  grid-column: 1 / -1;
  grid-row: 1;
}

.project-detail__gallery--count-5 .project-detail__gallery-cell:nth-child(2) {
  grid-column: 1 / span 2;
  grid-row: 2 / span 2;
  aspect-ratio: auto;
}

.project-detail__gallery--count-5 .project-detail__gallery-cell:nth-child(3) {
  grid-column: 3;
  grid-row: 2;
}

.project-detail__gallery--count-5 .project-detail__gallery-cell:nth-child(4) {
  grid-column: 4;
  grid-row: 2;
}

.project-detail__gallery--count-5 .project-detail__gallery-cell:nth-child(5) {
  grid-column: 3 / span 2;
  grid-row: 3;
}

.project-detail__gallery--count-4 .project-detail__gallery-cell:nth-child(1) {
  grid-column: 1 / -1;
  grid-row: 1;
}

.project-detail__gallery--count-4 .project-detail__gallery-cell:nth-child(2) {
  grid-column: 1;
  grid-row: 2;
}

.project-detail__gallery--count-4 .project-detail__gallery-cell:nth-child(3) {
  grid-column: 2;
  grid-row: 2;
}

.project-detail__gallery--count-4 .project-detail__gallery-cell:nth-child(4) {
  grid-column: 3;
  grid-row: 2;
}

.project-detail__gallery--count-3 .project-detail__gallery-cell:nth-child(1) {
  grid-column: 1 / -1;
  grid-row: 1;
}

.project-detail__gallery--count-3 .project-detail__gallery-cell:nth-child(2) {
  grid-column: 1;
  grid-row: 2;
}

.project-detail__gallery--count-3 .project-detail__gallery-cell:nth-child(3) {
  grid-column: 2;
  grid-row: 2;
}

.project-detail__gallery--count-2 {
  grid-template-columns: repeat(2, 1fr);
}

.project-detail__gallery--count-2 .project-detail__gallery-cell:nth-child(1) {
  grid-column: 1;
}

.project-detail__gallery--count-2 .project-detail__gallery-cell:nth-child(2) {
  grid-column: 2;
}

.project-detail__gallery--count-1 {
  grid-template-columns: 1fr;
}

.project-detail__desc {
  margin: 0.75rem 0 0;
  max-width: 65ch;
  color: var(--border-focus);
  line-height: 1.65;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}

.project-detail__social {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
  padding-block: var(--detail-pad-block);
  padding-inline: var(--detail-pad-inline);
  border-bottom: 1px solid var(--border);
}

.project-detail__stats {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
  width: 100%;
}

.project-detail__views {
  cursor: default;
  pointer-events: none;
}

.project-detail__like-form {
  margin: 0;
}

.project-detail__like-count {
  font-family: "Syne Mono", ui-monospace, monospace;
  font-size: 11px;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.project-like-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.project-like-wrap::before {
  content: "";
  position: absolute;
  bottom: 100%;
  left: 0;
  width: 100%;
  min-width: 180px;
  height: 14px;
}

.project-like-popover {
  position: absolute;
  bottom: calc(100% + 10px);
  left: 0;
  z-index: 30;
  min-width: 180px;
  max-width: min(320px, 90vw);
  padding: 1rem 1.25rem;
  background: var(--bg);
  border: 1px solid var(--border);
  opacity: 0;
  visibility: hidden;
  transform: translateY(4px);
  transition: opacity 0.15s ease, transform 0.15s ease, visibility 0.15s;
  pointer-events: none;
}

.project-like-wrap:hover .project-like-popover,
.project-like-wrap:focus-within .project-like-popover {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

@media (hover: none), (pointer: coarse), (max-width: 1024px) {
  .project-like-wrap::before,
  .project-like-popover {
    display: none !important;
  }
}

.project-like-popover__label {
  margin: 0 0 0.65rem;
}

.project-like-popover__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.45rem;
}

.project-like-popover__person {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text);
  opacity: 1;
}

.project-like-popover__person:hover {
  color: var(--text-muted);
  opacity: 1;
}

.project-like-popover__person:hover .user-avatar {
  border-color: var(--text-muted);
}

.user-avatar--liker {
  width: 28px;
  height: 28px;
  font-size: 0.72rem;
}

.project-like-popover__name {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.project-detail__comments {
  width: 50%;
  max-width: 100%;
  margin: 2rem auto;
  border: 1px solid var(--border);
}

@media (max-width: 768px) {
  .project-detail__comments {
    width: 100%;
  }
}

.project-detail__comments .comment-form.form {
  margin: 0;
  border-top: none;
  border-left: none;
  border-right: none;
}

.project-detail__comments .comment-form.form label {
  min-width: 0;
}

.comment-form__error {
  margin: 0;
  padding: 0 1.25rem 1rem;
  color: #f0a0a0;
  font-size: 0.9rem;
}

/* Inline field validation (replaces native browser tooltips) */
.field-error {
  margin: 0;
  padding-top: 0.35rem;
  font-family: "Syne Mono", ui-monospace, monospace;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #e8a4a4;
  line-height: 1.45;
}

.form label.field--invalid {
  color: #e8a4a4;
}

.form label.field--invalid input,
.form label.field--invalid textarea,
.form label.field--invalid select {
  color: #f5d0d0;
}

.chat-form .field-error {
  padding: 0 var(--page-pad) 0.75rem;
  border-bottom: 1px solid var(--border);
}

.chat-form textarea.field--invalid,
.chat-form.field--invalid textarea {
  color: #f5d0d0;
}

.project-detail__comments .comment-form.form button {
  width: 100%;
  margin: 0;
  border-top: 1px solid var(--border);
  border-radius: 0;
}

.project-detail__comments-note {
  margin: 0;
  padding: var(--page-pad);
  border-bottom: 1px solid var(--border);
  color: var(--text-muted);
  font-size: 0.95rem;
}

.project-detail__comments-note a {
  color: var(--text);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.project-detail__comments-note a:hover {
  opacity: 1;
  color: var(--text-muted);
}

/* ── Jobs ── */
.job-list {
  list-style: none;
  margin: 0;
  padding: 0;
  max-width: none;
  display: grid;
  gap: 0;
  border-top: 1px solid var(--border);
}

.job-card {
  display: block;
  margin: 0;
  padding: var(--page-pad);
  border: none;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
  border-radius: 0;
  color: var(--text);
  text-decoration: none;
  opacity: 1;
}

.job-card:hover {
  background: var(--surface-hover);
  color: var(--text);
  opacity: 1;
}

.job-card__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 0.5rem;
}

.job-card h2 {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 700;
}

.job-card__company {
  margin: 0.25rem 0 0;
  color: var(--text-muted);
}

.job-card__type {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0.4rem 0.65rem;
  border: 1px solid var(--border);
  flex-shrink: 0;
}

.job-detail .job-card__head > div:first-child {
  flex: 1;
  min-width: 0;
}

.job-detail__delete-form {
  margin: 0;
}

.job-card__meta {
  margin: 0 0 0.75rem;
  font-family: "Syne Mono", ui-monospace, monospace;
  font-size: 11px;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.job-card__desc {
  margin: 0;
  color: var(--text-muted);
  max-width: 60ch;
  line-height: 1.55;
  white-space: normal;
  overflow-wrap: anywhere;
}

.job-detail {
  max-width: none;
  margin: 0;
}

.job-detail__header h1 {
  font-size: clamp(1.75rem, 4vw, 2.75rem);
  font-weight: 800;
  margin: 0.5rem 0 0.25rem;
  line-height: 0.95;
}

.job-detail__body {
  padding: var(--page-pad);
  border-bottom: 1px solid var(--border);
}

.job-detail__body p,
.job-detail__description {
  margin: 0;
  max-width: 65ch;
  font-size: 1.05rem;
  line-height: 1.65;
  color: var(--border-focus);
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}

.job-detail__actions {
  padding: var(--page-pad);
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.job-detail__actions .eyebrow a:hover {
  color: var(--text);
  opacity: 1;
}

.comment-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.comment-item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1rem;
  align-items: start;
  padding: var(--page-pad);
  border-bottom: 1px solid var(--border);
}

.comment-item__avatar-link {
  display: block;
  flex-shrink: 0;
  text-decoration: none;
}

.comment-item__avatar-link:hover .user-avatar {
  border-color: var(--text);
}

.comment-item__content {
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  grid-template-areas:
    "meta actions"
    "body body";
  column-gap: 1rem;
  row-gap: 0.75rem;
  align-items: start;
}

.comment-item__content:not(:has(.comment-item__actions)) {
  grid-template-columns: 1fr;
  grid-template-areas:
    "meta"
    "body";
}

.comment-item__meta {
  grid-area: meta;
  margin: 0;
  min-width: 0;
}

.comment-item__meta-main {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
  flex-wrap: wrap;
  min-width: 0;
}

.comment-item__actions {
  grid-area: actions;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.75rem;
  flex-shrink: 0;
}

.comment-item__body,
.comment-item__edit-form,
.comment-reply-form {
  grid-column: 1 / -1;
}

.comment-item__action {
  font-family: "Syne Mono", ui-monospace, monospace;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  opacity: 1;
}

.comment-item__action:hover {
  color: var(--text);
  opacity: 1;
}

.comment-item__action--danger:hover {
  color: #f87171;
}

.comment-item__like-form {
  display: inline;
  margin: 0;
}

.comment-item__like-btn,
.comment-item__like-count {
  display: inline-flex;
  align-items: center;
  gap: 0.2rem;
  text-transform: none;
  letter-spacing: normal;
}

.comment-item__like-btn {
  font: inherit;
}

.comment-item__like-icon {
  font-size: 14px;
  line-height: 1;
}

.comment-item__like-btn.comment-item__action--active .comment-item__like-icon {
  color: var(--text);
}

.comment-item__like-count-num {
  font-family: "Syne Mono", ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.05em;
}

.comment-item__action--active {
  color: var(--text);
}

.comment-item__edit-form {
  margin: 0;
}

.comment-item__edit-label {
  display: block;
  margin: 0;
}

.comment-item__edit-form textarea {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--text);
  font: inherit;
  font-size: 1rem;
  line-height: 1.55;
}

.comment-item__edit-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.75rem;
}

.comment-item__meta a {
  color: var(--text);
  opacity: 1;
}

.comment-item__meta a:hover {
  color: var(--text-muted);
  opacity: 1;
}

.comment-item__meta time {
  flex-shrink: 0;
}

.comment-item__body {
  grid-area: body;
  margin: 0;
  max-width: 65ch;
  line-height: 1.65;
  color: var(--border-focus);
  white-space: pre-wrap;
}

.comment-replies {
  list-style: none;
  margin: 0;
  padding: 0;
  grid-column: 1 / -1;
  border-top: 1px solid var(--border);
}

.comment-item--reply {
  padding-left: calc(var(--page-pad) + 2.5rem);
  background: rgba(0, 0, 0, 0.25);
}

[data-theme="light"] .comment-item--reply {
  background: var(--bg);
}

.comment-item--reply .comment-item__avatar-link .user-avatar {
  width: 2rem;
  height: 2rem;
  font-size: 0.75rem;
}

.comment-reply-form {
  margin: 0.75rem 0 0;
}

.comment-reply-form__label {
  display: block;
  margin: 0;
}

.comment-reply-form textarea {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--text);
  font: inherit;
  font-size: 1rem;
  line-height: 1.55;
}

.comment-reply-form__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.75rem;
}

.project-card__likes {
  margin: 0.35rem 0 0;
  font-size: 0.75rem;
  color: var(--text-muted);
}

/* ── Messages ── */
.chat-thread {
  width: 50%;
  max-width: 100%;
  margin: 2rem auto;
  border: 1px solid var(--border);
}

@media (max-width: 768px) {
  .chat-thread {
    width: 100%;
  }
}

.chat-thread .chat-panel,
.chat-thread .chat,
.chat-thread .chat-form {
  max-width: none;
}

.chat-thread .chat-form .btn {
  border-bottom: none;
}

.chat-panel,
.thread-panel {
  max-width: none;
  margin: 0;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--border);
}

.chat-panel__header {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1.25rem;
  align-items: center;
  margin-top: 0.5rem;
}

.chat-panel__avatar-link {
  display: block;
  flex-shrink: 0;
  text-decoration: none;
}

.chat-panel__avatar-link:hover .user-avatar {
  border-color: var(--text);
}

.chat-panel__header-text h1 {
  margin: 0;
}

.chat-panel__header-text .eyebrow {
  margin: 0.35rem 0 0;
}

.chat {
  max-width: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0;
  border-bottom: 1px solid var(--border);
}

.chat__bubble[id^="message-"] {
  scroll-margin-top: 88px;
  scroll-margin-bottom: 2rem;
}

.chat__bubble {
  display: flex;
  align-items: flex-start;
  gap: 0.85rem;
  max-width: none;
  width: 100%;
  margin: 0;
  background: var(--bg);
  border: none;
  border-bottom: 1px solid var(--border);
  border-radius: 0;
  padding: 1rem 1.25rem;
  text-align: left;
}

.chat__bubble__avatar-link {
  flex-shrink: 0;
  text-decoration: none;
}

.chat__bubble__avatar-link:hover .user-avatar {
  border-color: var(--text);
}

.chat__bubble__content {
  flex: 1;
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  grid-template-areas:
    "body actions"
    "time actions";
  column-gap: 0.75rem;
  align-items: start;
}

.chat__bubble__content:not(:has(.chat__bubble__actions)) {
  grid-template-columns: 1fr;
  grid-template-areas:
    "body"
    "time";
}

.chat__bubble__actions {
  grid-area: actions;
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
}

.chat__bubble__like-form {
  display: inline;
  margin: 0;
}

.chat__bubble__like-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.2rem;
  font-family: inherit;
  font-size: 14px;
  line-height: 1;
  color: var(--text-muted);
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
}

.chat__bubble__like-btn--readonly {
  cursor: default;
}

.chat__bubble__like-btn:hover,
.chat__bubble__like-btn--active {
  color: var(--text);
}

.chat__bubble__like-btn--active .chat__bubble__like-icon {
  color: var(--text);
}

.chat__bubble__like-count {
  font-family: "Syne Mono", ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.05em;
}

.chat__bubble__text,
.chat__bubble__text--html {
  grid-area: body;
}

.chat__bubble--mine .chat__bubble__content {
  grid-template-areas:
    "actions body"
    "actions time";
}

.chat__bubble--mine .chat__bubble__content:not(:has(.chat__bubble__actions)) {
  grid-template-areas:
    "body"
    "time";
}

.chat__bubble--mine .chat__bubble__actions {
  justify-content: flex-start;
}

.chat__bubble__text {
  margin: 0;
  max-width: 65ch;
  line-height: 1.55;
  color: var(--text);
  white-space: pre-wrap;
}

.chat__bubble__text--html {
  max-width: none;
  white-space: normal;
}

.chat__bubble__text--html > :first-child {
  margin-top: 0;
}

.chat__bubble__text--html > :last-child {
  margin-bottom: 0;
}

.chat__bubble__content a {
  color: var(--text);
  font-weight: inherit;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.chat__bubble__content a:hover {
  color: var(--border-hover);
}

.chat__bubble--mine .chat__bubble__content a {
  color: var(--text);
}

.chat__bubble time {
  grid-area: time;
  display: block;
  margin: 0.4rem 0 0;
  font-family: "Syne Mono", ui-monospace, monospace;
  font-size: 11px;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.chat__bubble--mine {
  flex-direction: row-reverse;
  background: var(--surface-hover);
}

.chat__bubble--mine .chat__bubble__content {
  text-align: right;
}

.chat__bubble--mine .chat__bubble__text,
.chat__bubble--mine time {
  margin-left: auto;
  margin-right: 0;
}

#chat-compose {
  scroll-margin-bottom: 2.5rem;
}

.chat-form {
  max-width: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0;
  border: none;
}

.chat-form textarea {
  width: 100%;
  border: none;
  border-bottom: 1px solid var(--border);
  border-radius: 0;
  padding: var(--page-pad);
  background: var(--bg);
  color: var(--text);
  font: inherit;
  margin: 0;
  min-height: 120px;
}

.chat-form .btn {
  width: 100%;
  margin: 0;
  border-radius: 0;
  border: none;
  border-bottom: 1px solid var(--border);
}

.thread-list {
  list-style: none;
  margin: 0;
  padding: 0;
  max-width: none;
  border-top: 1px solid var(--border);
}

.user-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  overflow: hidden;
  background: var(--avatar-placeholder-bg);
  border: 1px solid var(--border);
  display: grid;
  place-items: center;
  flex-shrink: 0;
  font-weight: 700;
}

.user-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.project-detail__byline-avatar .user-avatar {
  width: 18px;
  height: 18px;
  font-size: 0.55rem;
}

.user-avatar--thread {
  width: 44px;
  height: 44px;
}

.user-avatar--chat {
  width: 56px;
  height: 56px;
}

.user-avatar--comment {
  width: 36px;
  height: 36px;
  font-size: 0.8rem;
}

.user-avatar--message {
  width: 36px;
  height: 36px;
  font-size: 0.8rem;
}

.thread-list > li > a.thread-item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1rem;
  align-items: start;
  width: 100%;
  padding: 1.25rem var(--page-pad);
  border: none;
  border-bottom: 1px solid var(--border);
  color: inherit;
  text-decoration: none;
}

.thread-list > li > a.thread-item:hover {
  opacity: 1;
}

.thread-item__content {
  position: relative;
  display: grid;
  gap: 0.25rem;
  min-width: 0;
  padding-right: 6.5rem;
}

.thread-item__time {
  position: absolute;
  top: 0;
  right: 0;
  margin: 0;
  font-family: "Syne Mono", ui-monospace, monospace;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted);
  white-space: nowrap;
}

.thread-item__preview {
  color: var(--text-muted);
  font-size: 0.95rem;
  line-height: 1.45;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.thread-item--unread {
  background: var(--surface-hover-strong);
  box-shadow: inset 4px 0 0 var(--highlight-ring);
}

.thread-item--unread strong,
.thread-item--unread .thread-item__time,
.thread-item--unread .thread-item__preview {
  color: var(--text);
}

.thread-item--unread strong::after {
  content: "New";
  margin-left: 0.45rem;
  padding: 0.1rem 0.4rem;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent-fg);
  background: var(--accent);
  vertical-align: middle;
}

.thread-item--unread .thread-item__preview {
  font-weight: 500;
}

/* ── Notifications & messages pages ── */
.notifications-page,
.messages-page,
.profile-panel[data-profile-panel="messages"] .profile-panel__section {
  width: 50%;
  max-width: 100%;
  margin-block: calc(var(--page-pad) * 1.5);
  margin-inline: auto;
  border: 1px solid var(--border);
}

@media (max-width: 768px) {
  .notifications-page,
  .messages-page,
  .profile-panel[data-profile-panel="messages"] .profile-panel__section {
    width: 100%;
    margin-block: var(--page-pad);
  }
}

.notifications-page .page-header,
.messages-page .page-header,
.profile-panel[data-profile-panel="messages"] .page-header {
  border-bottom: 1px solid var(--border);
}

.messages-page .thread-list,
.profile-panel[data-profile-panel="messages"] .thread-list {
  border-top: none;
}

.messages-page .thread-list > li > a.thread-item,
.profile-panel[data-profile-panel="messages"] .thread-list > li > a.thread-item {
  padding-block: calc(var(--page-pad) * 1.25);
  padding-inline: var(--page-pad);
}

.messages-page .empty {
  border-bottom: none;
}

.notifications-page .activity-feed {
  border-top: none;
}

.notifications-page .empty {
  border-bottom: none;
}

.activity-feed {
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1px solid var(--border);
}

.activity-item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1rem;
  align-items: start;
  padding: var(--page-pad);
  border-bottom: 1px solid var(--border);
}

.activity-item.is-unread {
  background: var(--surface-hover-strong);
  box-shadow: inset 4px 0 0 var(--highlight-ring);
}

.activity-item.is-unread .activity-item__kind::after {
  content: "New";
  margin-left: 0.5rem;
  padding: 0.1rem 0.4rem;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent-fg);
  background: var(--accent);
  vertical-align: middle;
}

.activity-item.is-unread .activity-item__kind,
.activity-item.is-unread time,
.activity-item.is-unread .activity-item__body,
.activity-item.is-unread .activity-item__quote,
.activity-item.is-unread .activity-item__quote a {
  color: var(--text);
}

.activity-item.is-unread .activity-item__body strong {
  color: var(--text);
}

.activity-item.is-unread .activity-item__kind {
  font-weight: 600;
  color: var(--text);
}

.activity-item__avatar-link {
  opacity: 1;
}

.activity-item__avatar-link:hover .user-avatar {
  border-color: var(--text-muted);
}

.user-avatar--activity {
  width: 48px;
  height: 48px;
}

.activity-item__content {
  min-width: 0;
}

.activity-item__meta {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  margin: 0 0 0.65rem;
}

.activity-item__kind {
  color: var(--text-muted);
}

.activity-item__body {
  margin: 0;
  line-height: 1.55;
  color: var(--text);
}

.activity-item__body a {
  opacity: 1;
}

.activity-item__body a:hover {
  color: var(--text-muted);
}

.activity-item__body strong {
  font-weight: 700;
}

.activity-item__quote {
  margin: 0.75rem 0 0;
  padding-left: 1rem;
  border-left: 1px solid var(--border);
  max-width: 65ch;
  line-height: 1.65;
  color: var(--border-hover);
  white-space: pre-wrap;
}

/* ── Admin ── */
.admin-tabs {
  display: flex;
  flex-wrap: nowrap;
  gap: 0;
  margin: 0;
  width: 100%;
  border-bottom: 1px solid var(--border);
}

.admin-tab {
  flex: 1 1 0;
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem 0.75rem;
  border-radius: 0;
  border: none;
  border-right: 1px solid var(--border);
  font-family: inherit;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  cursor: pointer;
  background: var(--bg);
  color: var(--text-muted);
}

.admin-tab:last-child {
  border-right: none;
}

.admin-tab.is-active {
  color: var(--text);
  background: var(--surface-hover-strong);
}

.admin-tab:hover {
  color: var(--text);
  background: var(--surface-hover);
}

.admin-panel[hidden] {
  display: none !important;
}

.admin-panels {
  --admin-pad-left: var(--page-pad);
  --admin-pad-right: 0.75rem;
  --admin-cell-pad-x: 0.85rem;
}

.admin-block {
  max-width: none;
  margin: 0;
  padding: 0;
  border-bottom: none;
}

.admin-block h2 {
  margin: 0;
  padding: 1.25rem var(--admin-pad-right) 1.25rem var(--admin-pad-left);
  border-bottom: 1px solid var(--border);
  font-size: 1.25rem;
}

.admin-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--bg);
  border-radius: 0;
}

.admin-table th,
.admin-table td {
  padding: 0.75rem var(--admin-cell-pad-x);
  border-bottom: 1px solid var(--border);
  text-align: left;
  vertical-align: middle;
}

.admin-panels .admin-table > thead > tr > th:first-child,
.admin-panels .admin-table > tbody > tr > td:first-child {
  padding-left: var(--admin-pad-left);
}

.admin-panels .admin-table > thead > tr > th:last-child,
.admin-panels .admin-table > tbody > tr > td:last-child {
  padding-right: var(--admin-pad-right);
}

.admin-panels .admin-table > thead > tr > th:last-child:not([colspan]),
.admin-panels .admin-table > tbody > tr > td:last-child:not([colspan]) {
  width: 1%;
  white-space: nowrap;
}

.admin-table__thumb {
  width: 72px;
  padding-right: 0.75rem;
}

.admin-thumb {
  display: block;
  width: 48px;
  height: 48px;
  object-fit: cover;
  border: 1px solid var(--border);
  background: var(--bg-elevated);
}

.admin-block:not(.admin-block--work) .admin-thumb {
  border-radius: 50%;
  overflow: hidden;
}

.admin-block:not(.admin-block--work) .admin-thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.admin-thumb--placeholder {
  display: grid;
  place-items: center;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text-muted);
}

.admin-thumb-link {
  display: block;
  width: fit-content;
  line-height: 0;
}

.admin-thumb-link:hover .admin-thumb {
  border-color: var(--text-muted);
}

.admin-block--work .admin-thumb {
  width: 120px;
  height: 72px;
}

.admin-block--work .admin-thumb--placeholder {
  width: 120px;
  height: 72px;
}

.admin-table--work th,
.admin-table--work td {
  padding: 0.6rem var(--admin-cell-pad-x);
  vertical-align: middle;
}

.admin-table--work th:first-child,
.admin-table--work td.admin-table__date {
  padding-left: var(--admin-pad-left);
  white-space: nowrap;
}

.admin-table--work td.admin-table__date {
  display: table-cell;
  vertical-align: bottom;
  font-variant-numeric: tabular-nums;
  color: var(--text-muted);
}

.admin-table--work td.admin-table__date time {
  display: block;
  font-family: "Syne Mono", ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.admin-table--work th.admin-table__thumb-head,
.admin-table--work td.admin-table__thumb {
  width: 1%;
  padding-left: 0.25rem;
  padding-right: 0.65rem;
  white-space: nowrap;
}

.admin-table--work th.admin-table__thumb-head {
  padding-top: 0;
  padding-bottom: 0;
}

.admin-table--work td:nth-child(3) {
  padding-left: 0.25rem;
  min-width: 8rem;
}

.admin-table--work .admin-table__likes {
  font-variant-numeric: tabular-nums;
  color: var(--text-muted);
  white-space: nowrap;
}

.admin-table--work td form {
  margin: 0;
}

.admin-table__sort {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  color: var(--text-muted);
  text-decoration: none;
  text-transform: inherit;
  letter-spacing: inherit;
  font: inherit;
}

.admin-table__sort:hover {
  color: var(--text);
}

.admin-table__sort.is-active {
  color: var(--text);
}

.admin-table__sort-indicator {
  font-size: 0.85em;
  line-height: 1;
}

.admin-table--creatives th,
.admin-table--creatives td {
  padding: 0.6rem var(--admin-cell-pad-x);
  vertical-align: middle;
}

.admin-table--creatives th:first-child,
.admin-table--creatives td.admin-table__date {
  padding-left: var(--admin-pad-left);
  white-space: nowrap;
}

.admin-table--creatives td.admin-table__date {
  display: table-cell;
  vertical-align: bottom;
  font-variant-numeric: tabular-nums;
  color: var(--text-muted);
}

.admin-table--creatives td.admin-table__date time {
  display: block;
  font-family: "Syne Mono", ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.admin-table--creatives th.admin-table__thumb-head,
.admin-table--creatives td.admin-table__thumb {
  width: 1%;
  padding-left: 0.25rem;
  padding-right: 0.65rem;
  white-space: nowrap;
}

.admin-table--creatives th.admin-table__thumb-head {
  padding-top: 0;
  padding-bottom: 0;
}

.admin-table--creatives td:nth-child(3) {
  padding-left: 0.25rem;
  min-width: 8rem;
}

.admin-table--creatives .admin-thumb,
.admin-table--creatives .admin-thumb--placeholder {
  width: 40px;
  height: 40px;
}

.admin-table--creatives .admin-thumb--placeholder {
  font-size: 0.85rem;
}

.admin-table--creatives .admin-table__likes {
  font-variant-numeric: tabular-nums;
  color: var(--text-muted);
  white-space: nowrap;
}

.admin-table--creatives td form {
  margin: 0;
}

/* ── Misc ── */
.auth-card--wide { max-width: none; }
.auth-card__lead {
  margin: 0.5rem 0 1.25rem;
  color: var(--text-muted);
  line-height: 1.5;
}

body.auth-page {
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
}

body.auth-page .auth-card--login,
body.auth-page .auth-card--register {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: none;
  margin: 0 auto;
  border-bottom: none;
}

.auth-card__inner {
  width: 100%;
  max-width: 22rem;
}

.auth-card--register .auth-card__inner {
  max-width: 28rem;
}

body.auth-page .auth-card__inner > .eyebrow,
body.auth-page .auth-card__inner > h1,
body.auth-page .auth-card__inner > .auth-card__lead,
body.auth-page .auth-card__inner > .auth-invite-note {
  text-align: center;
}

body.auth-page .auth-card__inner > h1 {
  padding-bottom: 1.25rem;
}

.auth-card__inner .form {
  width: 100%;
}

.auth-card__inner .form button {
  width: 100%;
}

.auth-invite-note {
  margin: 0 0 1rem;
  padding: 1rem 1.25rem;
  border: 1px solid var(--border);
  text-align: left;
  font-size: 0.95rem;
  color: var(--text-muted);
  line-height: 1.45;
}

.auth-card__helper {
  margin: 0.75rem 0 0;
  padding: 0;
  border: none;
  text-align: center;
  font-size: 0.85rem;
}

.auth-card__helper a {
  color: var(--text-muted);
  opacity: 1;
}

.auth-card__helper a:hover {
  color: var(--text);
}

.auth-card__legal {
  margin: 1rem 0 0;
  font-size: 0.85rem;
  line-height: 1.55;
  color: var(--text-muted);
  text-align: center;
}

.auth-card__legal a {
  color: var(--text);
}

.auth-card__footer {
  margin: 1rem 0 0;
  text-align: center;
  color: var(--text-muted);
}

.auth-card__footer .btn {
  display: block;
  width: 100%;
  margin-bottom: 0.75rem;
}

body.auth-page .footer {
  flex-shrink: 0;
}

@media (max-width: 520px) {
  .auth-card--register .form--grid {
    grid-template-columns: 1fr;
  }

  .auth-card--register .form--grid > label:nth-child(odd) {
    border-right: none;
  }
}

.admin-block__body {
  padding: var(--page-pad) var(--admin-pad-right) var(--page-pad) var(--admin-pad-left);
  border-bottom: 1px solid var(--border);
}

.admin-block__body--compact {
  padding-bottom: 0;
  border-bottom: none;
}

.admin-table__link {
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.admin-table__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem 1rem;
  white-space: nowrap;
}

.admin-table__inline-form {
  margin: 0;
  display: inline;
}

.admin-email-preview {
  padding: var(--page-pad);
  background: #111;
  border-bottom: 1px solid var(--border);
}

.admin-email-preview table {
  margin: 0 auto;
}

.admin-email-preview__text {
  margin: 0;
  padding: var(--page-pad);
  font-family: "Syne Mono", ui-monospace, monospace;
  font-size: 0.85rem;
  line-height: 1.5;
  color: var(--text-muted);
  white-space: pre-wrap;
  word-break: break-word;
  border-bottom: 1px solid var(--border);
}

.admin-block__lead {
  color: var(--text-muted);
  margin: 0 0 1.25rem;
  max-width: 40rem;
  line-height: 1.5;
}

.admin-block--invites .admin-invite-panel {
  max-width: 40rem;
}

.admin-invite-banner {
  margin-bottom: 1.25rem;
  padding: 1rem 1.15rem;
  border: 1px solid var(--border);
  background: var(--bg-elevated);
}

.admin-invite-banner__title {
  margin: 0 0 0.25rem;
  font-weight: 700;
}

.admin-invite-banner__hint {
  margin: 0 0 0.85rem;
  font-size: 0.9rem;
  color: var(--text-muted);
}

.admin-invite-banner__row {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  align-items: stretch;
}

.admin-invite-banner__input {
  flex: 1;
  min-width: 0;
  padding: 0.75rem 1rem;
  border: 1px solid var(--border);
  background: var(--media-bg);
  color: var(--text);
  font-family: "Syne Mono", ui-monospace, monospace;
  font-size: 0.75rem;
  line-height: 1.4;
}

.admin-invite-panel {
  border: 1px solid var(--border);
  background: var(--media-bg);
}

.admin-invite-panel__title {
  margin: 0;
  padding: 0.85rem 1.15rem;
  border-bottom: 1px solid var(--border);
  font-size: 0.95rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.admin-invite-form__fields {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}

.admin-invite-form__field {
  display: grid;
  gap: 0.35rem;
  padding: 1rem 1.15rem;
  border-bottom: 1px solid var(--border);
  border-right: 1px solid var(--border);
}

.admin-invite-form__field:nth-child(2n) {
  border-right: none;
}

.admin-invite-form__label {
  font-weight: 600;
}

.admin-invite-form__hint {
  font-size: 0.8rem;
  color: var(--text-muted);
  line-height: 1.35;
}

.admin-invite-form__field input {
  width: 100%;
  margin-top: 0.35rem;
  padding: 0.75rem 1rem;
  border: 1px solid var(--border);
  background: var(--bg-elevated);
  color: var(--text);
  font: inherit;
}

.admin-invite-form__actions {
  padding: 0.85rem 1.15rem;
}

.admin-invite-form__actions .btn {
  width: 100%;
}

.admin-badge {
  display: inline-block;
  padding: 0.2rem 0.5rem;
  border: 1px solid var(--border);
  font-family: "Syne Mono", ui-monospace, monospace;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.3;
}

.admin-badge--open {
  color: var(--text);
}

.admin-badge--used {
  color: var(--text-muted);
}

.admin-table__muted {
  color: var(--text-muted);
}

.admin-table__sub {
  display: block;
  margin-top: 0.25rem;
  font-size: 0.85rem;
  color: var(--text-muted);
}

time.admin-table__date,
span.admin-table__date {
  display: block;
  white-space: nowrap;
  font-family: "Syne Mono", ui-monospace, monospace;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
}

.admin-table--applications thead th {
  padding-top: 0.75rem;
  padding-bottom: 0.65rem;
}

.admin-table--applications .admin-application__time-row td {
  padding-top: 0.65rem;
  padding-bottom: 0.2rem;
  border-bottom: none;
  vertical-align: bottom;
}

.admin-table--applications .admin-application__data-row td {
  padding: 0.2rem var(--admin-cell-pad-x) 1.5rem;
  vertical-align: middle;
}

.admin-table--invites thead th {
  padding-top: 0.75rem;
  padding-bottom: 0.65rem;
}

.admin-table--invites .admin-invite__time-row td {
  padding-top: 0.65rem;
  padding-bottom: 0.2rem;
  border-bottom: none;
  vertical-align: bottom;
}

.admin-table--invites .admin-invite__data-row td {
  padding: 0.2rem var(--admin-cell-pad-x) 0.75rem;
  vertical-align: top;
}

.admin-table__note {
  max-width: 14rem;
  color: var(--text-muted);
}

.admin-table__action {
  text-align: right;
}

.admin-table__empty {
  color: var(--text-muted);
  text-align: center;
}

.admin-table__row--highlight {
  background: rgba(255, 255, 255, 0.04);
}

@media (max-width: 768px) {
  .page-header:has(+ .admin-tabs) {
    padding: 1rem var(--page-pad);
  }

  .page-header:has(+ .admin-tabs) h1 {
    font-size: clamp(1.35rem, 5vw, 2rem);
    line-height: 1.05;
  }

  .page-header:has(+ .admin-tabs) p {
    margin-top: 0.4rem;
    font-size: 0.9rem;
    line-height: 1.45;
  }

  .admin-tabs {
    overflow-x: auto;
    overscroll-behavior-x: contain;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }

  .admin-tabs::-webkit-scrollbar {
    display: none;
  }

  .admin-tab {
    flex: 0 0 auto;
    min-width: max(7.25rem, 22vw);
    padding: 0.9rem 1rem;
    font-size: 10px;
    letter-spacing: 0.1em;
  }

  .admin-panels {
    --admin-pad-left: 1rem;
    --admin-pad-right: 1rem;
    --admin-cell-pad-x: 1rem;
  }

  .admin-block h2 {
    padding: 1rem var(--admin-pad-right) 1rem var(--admin-pad-left);
    font-size: 1.1rem;
  }

  .admin-block__body,
  .admin-block__body--compact {
    padding: 1rem var(--admin-pad-right) 1rem var(--admin-pad-left);
  }

  .admin-block__lead {
    margin-bottom: 1rem;
    font-size: 0.9rem;
  }

  .admin-invite-banner {
    padding: 0.85rem 1rem;
  }

  .admin-invite-banner__row {
    flex-direction: column;
  }

  .admin-invite-banner__row .btn {
    width: 100%;
  }

  .admin-invite-form__fields {
    grid-template-columns: 1fr;
  }

  .admin-invite-form__field {
    border-right: none;
  }

  .admin-invite-form__field:nth-child(2n) {
    border-right: none;
  }

  .admin-table--cards {
    display: block;
    width: 100%;
  }

  .admin-table--cards thead {
    display: none;
  }

  .admin-table--cards tbody {
    display: block;
    padding: 0.75rem var(--admin-pad-left) 1.25rem;
  }

  .admin-table--cards .admin-table__empty-row {
    display: block;
    margin: 0;
    border: none;
    background: transparent;
  }

  .admin-table--cards .admin-table__empty-row td {
    display: block;
    padding: 2rem 0;
    text-align: center;
    border-bottom: none;
  }

  .admin-table--cards .admin-table__empty-row td::before {
    content: none;
  }

  .admin-table--cards .admin-application__time-row,
  .admin-table--cards .admin-invite__time-row {
    display: block;
    border: none;
    background: transparent;
  }

  .admin-table--cards .admin-application__time-row td,
  .admin-table--cards .admin-invite__time-row td {
    display: block;
    padding: 0.65rem 0 0.15rem;
    border-bottom: none;
    background: transparent;
  }

  .admin-table--cards .admin-application__data-row,
  .admin-table--cards .admin-invite__data-row,
  .admin-table--cards.admin-table--creatives tbody > tr,
  .admin-table--cards.admin-table--work tbody > tr {
    display: block;
    margin: 0 0 1rem;
    border: 1px solid var(--border);
    background: var(--bg-elevated);
  }

  .admin-table--cards .admin-table__row--highlight.admin-application__data-row,
  .admin-table--cards .admin-table__row--highlight.admin-invite__data-row,
  .admin-table--cards.admin-table--creatives .admin-table__row--highlight,
  .admin-table--cards.admin-table--work .admin-table__row--highlight {
    border-color: var(--text-muted);
    background: var(--surface-hover-strong);
  }

  .admin-table--cards .admin-application__data-row td,
  .admin-table--cards .admin-invite__data-row td,
  .admin-table--cards.admin-table--creatives tbody > tr > td,
  .admin-table--cards.admin-table--work tbody > tr > td {
    display: grid;
    grid-template-columns: minmax(4.75rem, 36%) 1fr;
    gap: 0.2rem 0.75rem;
    align-items: start;
    width: 100%;
    padding: 0.65rem 1rem;
    border-bottom: 1px solid var(--border);
    text-align: left;
    white-space: normal;
  }

  .admin-table--cards .admin-application__data-row td:last-child,
  .admin-table--cards .admin-invite__data-row td:last-child,
  .admin-table--cards.admin-table--creatives tbody > tr > td:last-child,
  .admin-table--cards.admin-table--work tbody > tr > td:last-child {
    border-bottom: none;
  }

  .admin-table--cards .admin-application__data-row td::before,
  .admin-table--cards .admin-invite__data-row td::before,
  .admin-table--cards.admin-table--creatives tbody > tr > td::before,
  .admin-table--cards.admin-table--work tbody > tr > td::before {
    content: attr(data-label);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-muted);
  }

  .admin-table--cards .admin-table__action {
    text-align: left;
  }

  .admin-table--cards .admin-table__inline-form,
  .admin-table--cards .admin-table__action .btn {
    width: 100%;
  }

  .admin-table--cards .admin-table__thumb {
    align-items: center;
  }

  .admin-table--cards .admin-thumb {
    width: 3rem;
    height: 3rem;
  }
}

.empty {
  color: var(--text-muted);
  padding: var(--page-pad);
  margin: 0;
  border-bottom: 1px solid var(--border);
}

.flash-stack {
  max-width: none;
  margin: 0;
  padding: 0 var(--page-pad);
  border-bottom: 1px solid var(--border);
}

.flash {
  padding: 1rem 1.25rem;
  border-radius: 0;
  margin: 0;
  border: none;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
}

.footer {
  border-top: 1px solid var(--border);
  padding: 2rem var(--page-pad);
  text-align: center;
  color: var(--text-muted);
  margin: 0;
}

.footer__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  flex-wrap: wrap;
}

.footer__copy {
  margin: 0;
}

.footer__socials {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0;
}

.footer__social {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 30px;
  height: 30px;
  border: 1px solid var(--border);
  border-radius: 50%;
  color: var(--border-hover);
  text-decoration: none;
  transition: color 0.15s ease, border-color 0.15s ease, background 0.15s ease;
}

.footer__social:hover {
  color: var(--text);
  border-color: var(--border-hover);
  background: var(--surface-hover-strong);
}

.footer__social-icon {
  display: block;
}

select option {
  background: var(--bg);
  color: var(--text);
}

/* ── Media upload mosaic grid (create / edit) ── */
.media-upload-section {
  padding: 0 0 var(--page-pad);
  border-bottom: 1px solid var(--border);
}

.media-upload-section__head {
  margin-bottom: 1rem;
  padding: 1rem 1.25rem 0;
}

.media-upload-section__title {
  margin: 0;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.media-upload-section__hint {
  margin: 0.35rem 0 0;
  color: var(--text-muted);
  font-size: 0.95rem;
}

.media-upload-section__add-more {
  margin: 0.75rem 1.25rem 0;
}

.media-upload-grid--has-media .media-slot--empty[hidden] {
  display: none !important;
}

.media-upload-grid .media-slot[hidden] {
  display: none !important;
}

.media-upload-grid--has-media .media-slot:not(.media-slot--empty) {
  display: block !important;
}

.media-upload-grid:not(.project-detail__media-mosaic) .media-slot--span-full {
  grid-column: 1 / -1 !important;
}

.media-upload-grid:not(.project-detail__media-mosaic) .media-slot:not(.media-slot--empty) [data-slot-trigger] {
  display: none !important;
}

.media-upload-grid:not(.project-detail__media-mosaic) .media-slot:not(.media-slot--empty) {
  aspect-ratio: auto;
}

.media-upload-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: auto;
  gap: 0;
  max-width: 100%;
}

.media-upload-grid:not(.project-detail__media-mosaic) {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-auto-rows: auto;
  gap: 0;
  border-top: 1px solid var(--border);
  border-left: 1px solid var(--border);
}

.media-upload-grid:not(.project-detail__media-mosaic) .media-slot {
  display: block;
  width: 100%;
  min-width: 0;
  align-self: start;
  aspect-ratio: auto;
  height: auto;
  min-height: 0;
}

.media-upload-grid:not(.project-detail__media-mosaic) .media-slot--empty {
  aspect-ratio: 16 / 9;
  min-height: 10rem;
}

.media-upload-grid:not(.project-detail__media-mosaic) .media-slot:not(.media-slot--empty) {
  position: relative;
  min-height: 0;
}

/* Upload preview: crop images to 4:3 (published project page keeps natural mosaic layout) */
.media-upload-grid:not(.project-detail__media-mosaic) .media-slot:has([data-slot-preview-img]:not([hidden])) {
  aspect-ratio: 4 / 3;
  overflow: hidden;
}

.media-upload-grid:not(.project-detail__media-mosaic) .media-slot:has([data-slot-preview-img]:not([hidden])) .media-slot__preview {
  position: absolute;
  inset: 0;
  display: block;
}

.media-upload-grid:not(.project-detail__media-mosaic) .media-slot:has([data-slot-preview-img]:not([hidden])) .media-slot__preview img[data-slot-preview-img] {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.media-upload-grid:not(.project-detail__media-mosaic) .media-slot:not(:has([data-slot-preview-img]:not([hidden]))) .media-slot__preview {
  position: relative;
  inset: auto;
  display: block;
}

.media-upload-grid:not(.project-detail__media-mosaic) .media-slot:not(.media-slot--empty) .media-slot__audio,
.media-upload-grid:not(.project-detail__media-mosaic) .media-slot:not(.media-slot--empty) .media-slot__video {
  position: relative;
  aspect-ratio: 16 / 9;
  min-height: 12rem;
}

.media-upload-grid:not(.project-detail__media-mosaic) .media-slot:not(.media-slot--empty) .media-slot__video iframe,
.media-upload-grid:not(.project-detail__media-mosaic) .media-slot:not(.media-slot--empty) .media-slot__video-player {
  position: absolute;
  inset: 0;
}

.media-slot {
  position: relative;
  margin: 0;
  width: 100%;
  min-width: 0;
  aspect-ratio: 16 / 9;
  border: none;
  border-right: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background: var(--bg-elevated);
  overflow: hidden;
  cursor: pointer;
}

.media-slot__file {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
  opacity: 0;
}

/* Upload work: empty cells use a full-size transparent file input so Safari opens the picker on click */
.media-upload-grid[data-direct-file-pick] .media-slot--empty .media-slot__file {
  inset: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  clip: auto;
  overflow: visible;
  cursor: pointer;
  z-index: 2;
}

.media-upload-grid[data-direct-file-pick] .media-slot--empty .media-slot__trigger {
  pointer-events: none;
}

.media-slot--empty {
  border-right: 2px dashed var(--border-strong);
  border-bottom: 2px dashed var(--border-strong);
}

.media-slot:not(.media-slot--empty) {
  cursor: default;
}

/* Project view — masonry grid (natural image heights, fills row width) */
.project-detail__media-mosaic-wrap {
  box-sizing: border-box;
  padding-top: var(--detail-pad-block);
  padding-inline: var(--detail-pad-inline);
}

.project-detail__media-mosaic.media-upload-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-auto-rows: auto;
  gap: 0;
  box-sizing: border-box;
  border-top: 1px solid var(--border);
  border-left: 1px solid var(--border);
}

.project-detail__media-mosaic .media-slot {
  display: block;
  width: 100%;
  min-width: 0;
  grid-column: auto !important;
  grid-row: auto !important;
  align-self: start !important;
  aspect-ratio: auto;
  height: auto;
  min-height: 0;
}

.project-detail__media-mosaic .media-slot:only-child,
.project-detail__media-mosaic .project-detail__media-cell--span-full {
  grid-column: 1 / -1 !important;
}

.project-detail__media-mosaic .media-slot[data-project-lightbox-cell] {
  cursor: zoom-in;
}

.project-detail__media-mosaic .media-slot--audio,
.project-detail__media-mosaic .project-detail__media-cell--audio {
  aspect-ratio: 16 / 9;
  min-height: 12rem;
  cursor: default;
}

.project-detail__media-mosaic .media-slot.project-detail__media-cell--video {
  aspect-ratio: auto;
  min-height: 0;
  cursor: zoom-in;
}

.project-detail__media-cell:focus-visible {
  outline: 2px solid var(--text);
  outline-offset: 2px;
}

.project-detail__media-cell {
  margin: 0;
}

.project-detail__media-mosaic .project-detail__media-cell--image img,
.project-detail__media-mosaic .project-detail__media-cell:not(.project-detail__media-cell--video):not(.project-detail__media-cell--audio) img {
  position: static;
  width: 100%;
  height: auto;
  display: block;
  border: none;
  pointer-events: none;
}

.project-detail__video-slot {
  position: relative;
  display: block;
  width: 100%;
}

.project-detail__media-mosaic .project-detail__video-slot iframe,
.project-detail__media-mosaic .project-detail__video-slot .media-slot__video-player {
  position: static;
  width: 100%;
  height: auto;
  display: block;
  border: none;
  pointer-events: auto;
}

.project-detail__video-lightbox-hit {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: max(2.5rem, 14%);
  z-index: 1;
  margin: 0;
  padding: 0;
  border: none;
  background: transparent;
  cursor: zoom-in;
}

.project-detail__video-lightbox-hit:focus-visible {
  outline: 2px solid var(--text);
  outline-offset: -2px;
}

@media (max-width: 768px) {
  /* Corner target only — full-area overlay blocks the native / embed play control */
  .project-detail__video-lightbox-hit {
    inset: auto;
    top: 0.5rem;
    right: 0.5rem;
    left: auto;
    bottom: auto;
    width: 2.75rem;
    height: 2.75rem;
  }
}

.project-detail__media-mosaic .project-detail__media-cell--image img {
  object-fit: cover;
  pointer-events: none;
}

.project-detail__media-mosaic .project-detail__media-cell--video .media-slot__video-player {
  background: var(--media-bg);
}

.project-detail__media-mosaic .project-detail__media-cell--video iframe {
  aspect-ratio: auto;
  min-height: 0;
  object-fit: unset;
  background: var(--media-bg);
}

.project-detail__media-mosaic .project-detail__media-cell--video-embed iframe {
  aspect-ratio: 16 / 9;
}

.project-detail__media-cell img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  border: none;
  pointer-events: none;
}

.project-detail__media-cell iframe,
.project-detail__media-cell .media-slot__video-player {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  border: none;
  pointer-events: auto;
}

.project-detail__media-cell iframe {
  object-fit: unset;
  background: var(--media-bg);
}

.project-detail__media-cell .media-slot__video-player {
  object-fit: cover;
}

.project-detail__media-cell .media-slot__audio .waveform-player {
  pointer-events: auto;
}

.project-lightbox {
  padding: 0;
  margin: 0;
  border: none;
  width: 100%;
  max-width: 100%;
  height: 100%;
  max-height: 100%;
  background: transparent;
  overflow: hidden;
}

.project-lightbox::backdrop {
  background: var(--overlay);
}

/* Non-modal open so native video fullscreen is not cancelled by the dialog top layer */
.project-lightbox.project-lightbox--video-mode[open] {
  position: fixed;
  inset: 0;
  z-index: 1200;
  width: 100%;
  max-width: none;
  height: 100%;
  max-height: none;
  background: var(--overlay);
}

.project-lightbox__close {
  position: fixed;
  top: 1rem;
  right: 1rem;
  z-index: 2;
  width: 44px;
  height: 44px;
  padding: 0;
  border: 1px solid var(--border-strong);
  background: var(--overlay);
  color: var(--overlay-fg);
  font-size: 1.75rem;
  line-height: 1;
  cursor: pointer;
  font: inherit;
}

.project-lightbox__close:hover {
  border-color: var(--overlay-fg);
  background: var(--scrim);
}

.project-lightbox__stage {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 100vh;
  padding: 3.5rem 1.25rem 1.25rem;
  box-sizing: border-box;
}

.project-lightbox__image {
  display: block;
  max-width: min(96vw, 1600px);
  max-height: 90vh;
  width: auto;
  height: auto;
  object-fit: contain;
}

.project-lightbox__iframe {
  width: min(96vw, 1200px);
  aspect-ratio: 16 / 9;
  height: auto;
  max-height: 85vh;
  border: none;
  background: var(--media-bg);
}

/* Waveform audio player (SoundCloud-style) */
.waveform-player {
  width: 100%;
}

.waveform-player__filename {
  margin: 0;
  font-size: 11px;
  letter-spacing: 0.02em;
  color: var(--text-muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: calc(100% - 1rem);
}

.waveform-player__bar {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  width: 100%;
  min-width: 0;
}

.waveform-player__play {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 1fr;
  place-items: center;
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: 50%;
  background: var(--bg);
  color: var(--text);
  cursor: pointer;
  font: inherit;
}

.waveform-player__play:hover {
  border-color: var(--text);
}

.waveform-player__icon {
  display: block;
  width: 18px;
  height: 18px;
  grid-area: 1 / 1;
}

.waveform-player__icon--pause {
  display: none;
}

.waveform-player.is-playing .waveform-player__icon--play {
  display: none;
}

.waveform-player.is-playing .waveform-player__icon--pause {
  display: block;
}

.waveform-player__track {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: stretch;
  flex: 1;
  min-width: 0;
  height: 52px;
  cursor: pointer;
}

.waveform-player__canvas {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 0;
  align-self: center;
}

.waveform-player__time {
  flex-shrink: 0;
  min-width: 2.75rem;
  font-family: "Syne Mono", ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
}

.waveform-player.is-loading .waveform-player__canvas {
  opacity: 0.45;
}

.waveform-player--compact {
  position: absolute;
  inset: 0;
  background: var(--bg-elevated);
}

.waveform-player--compact .waveform-player__filename {
  position: absolute;
  top: 0.65rem;
  left: 0.75rem;
  z-index: 2;
  text-align: left;
}

.waveform-player--compact .waveform-player__bar {
  position: absolute;
  inset: 0;
  display: block;
}

.waveform-player--compact .waveform-player__track {
  position: absolute;
  top: calc(50% - 1.75rem);
  left: 0.5rem;
  right: 0.5rem;
  width: auto;
  height: 36%;
  max-height: 44%;
  margin: 0;
  transform: translateY(-50%);
  display: block;
  flex: none;
}

.waveform-player--compact .waveform-player__canvas {
  width: 100%;
  height: 100%;
}

.waveform-player--compact .waveform-player__play {
  position: absolute;
  bottom: 2.25rem;
  left: 50%;
  z-index: 2;
  width: 60px;
  height: 60px;
  margin: 0;
  transform: translateX(-50%);
}

.waveform-player--compact .waveform-player__icon {
  width: 27px;
  height: 27px;
}

.waveform-player--compact .waveform-player__time--current,
.waveform-player--compact .waveform-player__time--duration {
  position: absolute;
  bottom: 2.2rem;
  z-index: 2;
  display: block;
  min-width: 2.75rem;
  padding: 0;
  font-size: 10px;
}

.waveform-player--compact .waveform-player__time--current {
  left: 2.25rem;
  text-align: left;
}

.waveform-player--compact .waveform-player__time--duration {
  right: 2.25rem;
  text-align: right;
}

.waveform-player--lightbox {
  width: min(96vw, 640px);
  padding: 1.25rem 1.5rem;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
}

.waveform-player--lightbox .waveform-player__filename {
  margin: 0 0 0.85rem;
  max-width: none;
  text-align: left;
}

.waveform-player--lightbox .waveform-player__track {
  height: 64px;
}

.project-lightbox__video {
  display: block;
  width: min(96vw, 1200px);
  max-width: 100%;
  max-height: 85vh;
  height: auto;
  object-fit: contain;
  background: var(--media-bg);
}

.media-slot__trigger {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  min-height: 100%;
  padding: 0;
  border: none;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  font: inherit;
  text-align: center;
}

.media-slot--empty:hover,
.media-slot--empty:focus-within {
  border-color: var(--border-hover);
  background: var(--surface-hover);
}

.media-upload-grid[data-direct-file-pick] .media-slot.is-drag-over {
  border-color: var(--border-hover);
  background: var(--surface-hover-strong);
}

.media-upload-grid[data-direct-file-pick] .media-slot.is-drag-over .media-slot__plus {
  color: var(--text);
}

.media-upload-grid[data-direct-file-pick] .media-slot.is-processing {
  pointer-events: none;
  opacity: 0.65;
}

.media-upload-grid[data-direct-file-pick] .media-slot.is-processing::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 4;
  background: rgba(0, 0, 0, 0.35);
}

.media-slot__trigger:hover .media-slot__plus {
  color: var(--text);
}

.media-slot__plus {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: clamp(2.75rem, 10vw, 4.75rem);
  font-weight: 300;
  line-height: 1;
  color: var(--text-faint);
  pointer-events: none;
  user-select: none;
}

.media-slot--empty .media-slot__preview {
  display: none !important;
}

.media-slot__preview[hidden] {
  display: none !important;
}

.media-slot__preview {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  background: var(--bg-elevated);
}

.media-slot__preview img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.media-slot__preview img[hidden],
.media-slot__preview img:not([src]) {
  display: none !important;
}

.media-slot__preview iframe:not([src]) {
  display: none !important;
}

.media-slot__preview [hidden] {
  display: none !important;
}

.media-slot__audio,
.media-slot__video {
  position: absolute;
  inset: 0;
}

.media-slot__audio .waveform-player {
  z-index: 1;
  pointer-events: auto;
}

.media-slot__video-player {
  pointer-events: auto;
}

.media-slot__video iframe,
.media-slot__video-player {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
  background: var(--media-bg);
  object-fit: cover;
}

.media-slot__remove {
  position: absolute;
  right: 0.5rem;
  bottom: 0.5rem;
  z-index: 3;
  padding: 0.35rem 0.55rem;
  border: 1px solid rgba(255, 120, 120, 0.45);
  background: rgba(0, 0, 0, 0.85);
  color: #ff9a9a;
  font: inherit;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
}

.media-modal {
  padding: 0;
  border: 1px solid var(--border);
  border-radius: 0;
  background: var(--bg);
  color: var(--text);
  max-width: min(480px, calc(100vw - 48px));
  width: 100%;
}

.media-modal::backdrop {
  background: var(--overlay);
}

.media-modal__panel {
  display: grid;
  gap: 0;
  margin: 0;
  padding: 0;
}

.media-modal__panel > .eyebrow {
  margin: 0;
  padding: 1rem 1.25rem 0;
}

.media-modal__heading {
  margin: 0;
  padding: 0.35rem 1.25rem 0;
  font-size: 1.35rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.1;
}

.media-modal__hint {
  margin: 0;
  padding: 0.5rem 1.25rem 1rem;
  color: var(--text-muted);
  font-size: 0.95rem;
  line-height: 1.5;
  border-bottom: 1px solid var(--border);
}

.media-modal__field {
  display: grid;
  gap: 0.5rem;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--border);
}

.media-modal__field input {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--text);
  font: inherit;
  font-size: 0.95rem;
}

.media-modal__error {
  margin: 0;
  padding: 0 1.25rem 1rem;
  color: #e8a4a4;
  font-family: "Syne Mono", ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.media-modal__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  padding: 1rem 1.25rem;
}

.media-modal__actions--end {
  justify-content: flex-end;
}

.delete-account-modal__eyebrow {
  color: #c97878;
}

.delete-account-modal .media-modal__heading {
  color: #ff8a8a;
}

.delete-account-modal .media-modal__actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  padding: 0;
  border-top: 1px solid var(--border);
}

.delete-account-modal .media-modal__actions .btn {
  width: 100%;
  margin: 0;
  border: none;
  border-radius: 0;
}

.delete-account-modal .media-modal__actions .btn + .btn {
  border-left: 1px solid var(--border);
}

.logout-modal__eyebrow {
  color: var(--text-muted);
}

.logout-modal .media-modal__heading {
  color: var(--text);
}

.logout-modal .media-modal__actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  padding: 0;
  border-top: 1px solid var(--border);
}

.logout-modal .media-modal__actions .btn {
  width: 100%;
  margin: 0;
  border: none;
  border-radius: 0;
}

.logout-modal .media-modal__actions .btn + .btn {
  border-left: 1px solid var(--border);
}

.comment-delete-modal__eyebrow {
  color: var(--text-muted);
}

.comment-delete-modal .media-modal__heading {
  color: var(--text);
}

.comment-delete-modal .media-modal__actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  padding: 0;
  border-top: 1px solid var(--border);
}

.comment-delete-modal .media-modal__actions .btn {
  width: 100%;
  margin: 0;
  border: none;
  border-radius: 0;
}

.comment-delete-modal .media-modal__actions .btn + .btn {
  border-left: 1px solid var(--border);
}

.comment-delete-modal__preview {
  margin: 0;
  padding: 0.75rem 1.25rem 1rem;
  border-bottom: 1px solid var(--border);
  color: var(--text-muted);
  font-size: 0.92rem;
  font-style: normal;
  line-height: 1.55;
  white-space: pre-wrap;
  max-height: 7rem;
  overflow: hidden;
}

.comment-delete-modal__preview[hidden] {
  display: none;
}

.comment-delete-modal .media-modal__error {
  border-bottom: 1px solid var(--border);
}

.media-chooser-modal__options {
  display: grid;
  border-top: 1px solid var(--border);
}

.media-chooser-modal__option {
  padding: 1rem 1.25rem;
  border: none;
  border-bottom: 1px solid var(--border);
  background: transparent;
  color: var(--text);
  font: inherit;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-align: left;
  cursor: pointer;
}

.media-chooser-modal__option:last-child {
  border-bottom: none;
}

.media-chooser-modal__option:hover {
  background: var(--surface-hover-strong);
}

.media-chooser-modal__loading {
  display: grid;
  justify-items: start;
  gap: 0;
  padding-bottom: 1.25rem;
}

.media-chooser-modal__loading[hidden] {
  display: none !important;
}

.media-modal__panel[data-chooser-panel][hidden] {
  display: none !important;
}

.media-modal__spinner {
  width: 2rem;
  height: 2rem;
  margin: 1.25rem 1.25rem 0;
  border: 2px solid var(--border);
  border-top-color: var(--text);
  border-radius: 50%;
  animation: media-modal-spin 0.7s linear infinite;
}

@keyframes media-modal-spin {
  to {
    transform: rotate(360deg);
  }
}

.btn--compact {
  padding: 0.5rem 0.75rem;
  font-size: 10px;
}

/* ── Project edit: file history ── */
.project-edit__panel {
  padding: var(--page-pad);
  border-bottom: 1px solid var(--border);
}

.project-edit__panel-head {
  margin-bottom: 1rem;
}

.project-edit__panel-title {
  margin: 0;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.project-edit__panel-hint,
.project-edit__empty {
  margin: 0.35rem 0 0;
  color: var(--text-muted);
  font-size: 0.95rem;
}

.project-edit-gallery__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--border);
  border-left: 1px solid var(--border);
}

.project-edit-gallery__grid + .project-edit-gallery__grid {
  border-top: none;
}

.project-edit-gallery__item {
  position: relative;
  margin: 0;
  min-height: 140px;
  border-right: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background: var(--bg);
  cursor: grab;
  overflow: hidden;
}

/* Edit mosaic — same layout as project page (hero + large left + 2×2 right) */
.project-edit-gallery__grid--count-6 {
  grid-template-rows: minmax(200px, 36vw) minmax(160px, 24vw) minmax(160px, 24vw);
}

.project-edit-gallery__grid--count-6 .project-edit-gallery__item:nth-child(1) {
  grid-column: 1 / -1;
}

.project-edit-gallery__grid--count-6 .project-edit-gallery__item:nth-child(2) {
  grid-column: 1 / span 2;
  grid-row: 2 / span 2;
}

.project-edit-gallery__grid--count-6 .project-edit-gallery__item:nth-child(3) {
  grid-column: 3;
  grid-row: 2;
}

.project-edit-gallery__grid--count-6 .project-edit-gallery__item:nth-child(4) {
  grid-column: 4;
  grid-row: 2;
}

.project-edit-gallery__grid--count-6 .project-edit-gallery__item:nth-child(5) {
  grid-column: 3;
  grid-row: 3;
}

.project-edit-gallery__grid--count-6 .project-edit-gallery__item:nth-child(6) {
  grid-column: 4;
  grid-row: 3;
}

.project-edit-gallery__grid--count-5 {
  grid-template-rows: minmax(200px, 36vw) minmax(160px, 24vw) minmax(160px, 24vw);
}

.project-edit-gallery__grid--count-5 .project-edit-gallery__item:nth-child(1) {
  grid-column: 1 / -1;
}

.project-edit-gallery__grid--count-5 .project-edit-gallery__item:nth-child(2) {
  grid-column: 1 / span 2;
  grid-row: 2 / span 2;
}

.project-edit-gallery__grid--count-5 .project-edit-gallery__item:nth-child(3) {
  grid-column: 3;
  grid-row: 2;
}

.project-edit-gallery__grid--count-5 .project-edit-gallery__item:nth-child(4) {
  grid-column: 4;
  grid-row: 2;
}

.project-edit-gallery__grid--count-5 .project-edit-gallery__item:nth-child(5) {
  grid-column: 3 / span 2;
  grid-row: 3;
}

.project-edit-gallery__grid--count-4 {
  grid-template-rows: minmax(200px, 36vw) minmax(160px, 24vw);
}

.project-edit-gallery__grid--count-4 .project-edit-gallery__item:nth-child(1) {
  grid-column: 1 / -1;
}

.project-edit-gallery__grid--count-4 .project-edit-gallery__item:nth-child(2) {
  grid-column: 1 / span 2;
  grid-row: 2;
}

.project-edit-gallery__grid--count-4 .project-edit-gallery__item:nth-child(3) {
  grid-column: 3;
  grid-row: 2;
}

.project-edit-gallery__grid--count-4 .project-edit-gallery__item:nth-child(4) {
  grid-column: 4;
  grid-row: 2;
}

.project-edit-gallery__grid--count-3 {
  grid-template-rows: minmax(200px, 36vw) minmax(180px, 28vw);
}

.project-edit-gallery__grid--count-3 .project-edit-gallery__item:nth-child(1) {
  grid-column: 1 / -1;
}

.project-edit-gallery__grid--count-3 .project-edit-gallery__item:nth-child(2) {
  grid-column: 1 / span 2;
  grid-row: 2;
}

.project-edit-gallery__grid--count-3 .project-edit-gallery__item:nth-child(3) {
  grid-column: 3 / span 2;
  grid-row: 2;
}

.project-edit-gallery__grid--count-2 {
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: minmax(240px, 42vw);
}

.project-edit-gallery__grid--count-1 {
  grid-template-columns: 1fr;
  grid-template-rows: minmax(260px, 50vw);
}

.project-edit-gallery__item.is-dragging {
  opacity: 0.45;
  cursor: grabbing;
}

.project-edit-gallery__item.is-drag-over {
  outline: 2px solid var(--border-focus);
  outline-offset: -2px;
}

.project-edit-gallery__item.is-removed {
  display: none;
}

.project-edit-gallery__item img {
  width: 100%;
  height: 100%;
  min-height: 140px;
  object-fit: cover;
  display: block;
  pointer-events: none;
}

.project-edit-gallery__pos {
  position: absolute;
  top: 0.5rem;
  left: 0.5rem;
  z-index: 2;
  padding: 0.25rem 0.45rem;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  background: rgba(0, 0, 0, 0.72);
  border: 1px solid var(--border);
  color: var(--text-muted);
}

.project-edit-gallery__pos.is-hero {
  color: var(--text);
  border-color: var(--text-muted);
}

.project-edit-gallery__remove {
  position: absolute;
  right: 0.5rem;
  bottom: 0.5rem;
  z-index: 2;
  padding: 0.35rem 0.55rem;
  border: 1px solid rgba(255, 120, 120, 0.45);
  background: rgba(0, 0, 0, 0.8);
  color: #ff9a9a;
  font: inherit;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
}

.project-edit-gallery__remove:hover {
  border-color: rgba(255, 140, 140, 0.75);
  color: #ffc0c0;
}

.project-edit__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  padding: var(--page-pad);
  border-bottom: 1px solid var(--border);
}

.form-page--detail-pad .project-edit__actions,
.form-page--detail-pad .project-edit-history {
  padding-inline: 0;
  padding-block: var(--detail-pad-block);
}

.project-edit-history {
  margin: 0;
  padding: var(--page-pad);
  border-bottom: 1px solid var(--border);
}

.project-edit-history__title {
  margin: 0 0 1rem;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.project-edit-history__list {
  list-style: none;
  margin: 0;
  padding: 0;
  border: 1px solid var(--border);
}

.project-edit-history__item {
  padding: 0.85rem 1rem;
  border-bottom: 1px solid var(--border);
}

.project-edit-history__item:last-child {
  border-bottom: none;
}

.project-edit-history__meta {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 0.25rem;
}

.project-edit-history__action {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.project-edit-history__meta time {
  font-size: 11px;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
}

.project-edit-history__summary {
  margin: 0;
  color: var(--text);
  font-size: 0.95rem;
}

.project-edit-history__file {
  margin: 0.25rem 0 0;
  font-family: "Syne Mono", ui-monospace, monospace;
  font-size: 11px;
  color: rgba(238, 238, 238, 0.5);
  word-break: break-all;
}

@media (max-width: 800px) {
  :root {
    --page-pad: 24px;
  }

  /* Project page — match upload work gutters on small screens */
  .project-detail {
    --detail-pad-inline: var(--page-pad);
    --detail-pad-block: var(--page-pad);
  }

  .project-detail__media-mosaic-wrap {
    padding-inline: 0;
    padding-top: var(--page-pad);
  }

  .project-detail__media-mosaic.media-upload-grid {
    border-left: none;
    border-right: none;
  }

  /* Upload work — full-bleed form grids; title/lead keep single gutter */
  .form-page.form-page--detail-pad {
    --detail-pad-inline: var(--page-pad);
    --detail-pad-block: var(--page-pad);
    padding-block: var(--detail-pad-block) 0;
    padding-inline: 0;
  }

  .form-page.form-page--detail-pad > h1,
  .form-page.form-page--detail-pad > .form-page__lead {
    padding-inline: var(--detail-pad-inline);
    margin: 0;
  }

  .form-page.form-page--detail-pad > .form-page__lead {
    padding-block: 0 1rem;
    color: var(--text-muted);
    line-height: 1.5;
  }

  .form-page.form-page--detail-pad > .form {
    border-left: none;
    border-right: none;
  }

  .form-page.form-page--detail-pad > .project-edit__actions,
  .form-page.form-page--detail-pad > .project-edit-history {
    padding-inline: var(--detail-pad-inline);
  }

  .nav-toggle {
    display: inline-flex;
    margin-left: auto;
  }

  .nav.is-open {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 40;
  }

  .nav-menu {
    display: none;
    position: fixed;
    left: 0;
    right: 0;
    top: var(--nav-bar-height, 80px);
    bottom: 0;
    z-index: 39;
    flex: none;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: 0;
    padding: 0;
    background: var(--bg);
    border-top: 1px solid var(--border);
    overflow-y: auto;
  }

  .nav.is-open .nav-menu {
    display: flex;
  }

  .nav-center,
  .nav-end {
    flex: none;
    flex-direction: column;
    align-items: stretch;
    width: 100%;
    gap: 0;
  }

  .nav-center {
    position: static;
    transform: none;
    border-bottom: 1px solid var(--border);
  }

  .nav-center__link,
  .nav-end__link,
  .nav-login-btn,
  .nav-apply-btn {
    display: block;
    width: 100%;
    padding: 1.1rem var(--page-pad);
    border-bottom: 1px solid var(--border);
    text-align: left;
  }

  .nav-end {
    flex-wrap: wrap;
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem var(--page-pad) 1.25rem;
  }

  .nav-end .nav-end__link {
    flex: 1 1 100%;
    border: 1px solid var(--border);
    text-align: center;
  }

  .nav-login-btn,
  .nav-apply-btn {
    flex: 1 1 calc(50% - 0.375rem);
    border: 1px solid var(--border);
    text-align: center;
  }

  .nav-apply-btn {
    border: none;
  }

  .filters,
  .filters--jobs {
    grid-template-columns: 1fr;
  }

  .job-detail .job-card__head {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.75rem;
  }

  .job-detail__header h1 {
    overflow-wrap: anywhere;
  }

  .job-detail__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .job-detail__actions .btn {
    width: 100%;
    justify-content: center;
  }

  .filters > * {
    border-bottom: none;
  }

  .form--grid { grid-template-columns: 1fr; }
  .form--grid label { border-right: none; }

  .form-disciplines--bleed .form-disciplines__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .discipline-filter__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .discipline-filter__cell:nth-child(4n) {
    border-right: 1px solid var(--border);
  }

  .discipline-filter__cell:nth-child(2n) {
    border-right: none;
  }

  .profile-hero {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .profile-hero__avatar { margin: 0 auto; }
  .profile-hero__meta {
    justify-content: center;
    width: 100%;
  }

  .profile-hero__meta .eyebrow {
    text-align: center;
  }

  .profile-hero__name-row { justify-content: center; }
  .profile-links { justify-content: center; }

  .profile-actions .btn,
  .profile-tab {
    padding: 0.85rem 0.4rem;
    font-size: 9px;
    letter-spacing: 0.08em;
  }

  .tabs { flex-direction: column; }
  .tabs a {
    border-right: none;
    border-bottom: 1px solid var(--border);
  }
  .tabs a:last-child { border-bottom: none; }

  .project-detail__gallery,
  .project-detail__gallery--count-1,
  .project-detail__gallery--count-2,
  .project-detail__gallery--count-3,
  .project-detail__gallery--count-4,
  .project-detail__gallery--count-5,
  .project-detail__gallery--count-6 {
    grid-template-columns: 1fr;
    grid-auto-rows: auto;
  }

  .project-detail__header {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }

  .project-detail__byline {
    align-items: flex-start;
  }

  .project-detail__thumb {
    max-width: 100%;
  }

  .media-upload-grid:not(.project-detail__media-mosaic) {
    grid-template-columns: 1fr;
  }

  .project-detail__media-mosaic.media-upload-grid {
    grid-template-columns: 1fr;
  }

  .project-edit-gallery__grid,
  .project-edit-gallery__grid--count-1,
  .project-edit-gallery__grid--count-2,
  .project-edit-gallery__grid--count-3,
  .project-edit-gallery__grid--count-4,
  .project-edit-gallery__grid--count-5,
  .project-edit-gallery__grid--count-6 {
    grid-template-columns: 1fr;
    grid-template-rows: none;
    grid-auto-rows: minmax(200px, 55vw);
  }

  .project-edit-gallery__item,
  .project-edit-gallery__grid--count-2 .project-edit-gallery__item,
  .project-edit-gallery__grid--count-3 .project-edit-gallery__item,
  .project-edit-gallery__grid--count-4 .project-edit-gallery__item,
  .project-edit-gallery__grid--count-5 .project-edit-gallery__item,
  .project-edit-gallery__grid--count-6 .project-edit-gallery__item {
    grid-column: 1 !important;
    grid-row: auto !important;
  }

  .project-edit-history__meta {
    flex-direction: column;
    gap: 0.2rem;
  }

  .project-detail__gallery-cell,
  .project-detail__gallery--count-2 .project-detail__gallery-cell,
  .project-detail__gallery--count-3 .project-detail__gallery-cell,
  .project-detail__gallery--count-4 .project-detail__gallery-cell,
  .project-detail__gallery--count-5 .project-detail__gallery-cell,
  .project-detail__gallery--count-6 .project-detail__gallery-cell {
    grid-column: 1 !important;
    grid-row: auto !important;
    aspect-ratio: 16 / 9;
  }

  .cookie-banner__inner {
    flex-direction: column;
    align-items: stretch;
    gap: 0.5rem;
  }

  .cookie-banner__copy {
    flex: 0 0 auto;
    width: 100%;
  }

  .cookie-banner__actions {
    width: 100%;
  }

  .cookie-banner__actions .btn {
    flex: 1 1 auto;
    justify-content: center;
  }

  .cookie-consent-modal__actions {
    flex-direction: column;
  }

  .cookie-consent-modal__actions .btn {
    width: 100%;
    justify-content: center;
  }
}

/* ── Cookie consent ── */
body.has-cookie-banner {
  padding-bottom: 7.5rem;
}

.cookie-banner {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 60;
  border-top: 1px solid var(--border);
  background: var(--bg-elevated);
  box-shadow: 0 -8px 28px var(--shadow);
}

.cookie-banner[hidden] {
  display: none !important;
}

.cookie-banner__inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem 1.5rem;
  max-width: none;
  margin: 0;
  padding: 1rem var(--page-pad);
}

.cookie-banner__copy {
  flex: 0 0 auto;
  min-width: 0;
}

.cookie-banner__eyebrow {
  margin: 0 0 0.35rem;
}

.cookie-banner__text {
  margin: 0;
  max-width: 52ch;
  color: var(--text-muted);
  font-size: 0.95rem;
  line-height: 1.55;
}

.cookie-banner__text a {
  color: var(--text);
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.cookie-banner__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}

.cookie-consent-modal {
  max-width: min(520px, calc(100vw - 48px));
}

.cookie-consent-modal .media-modal__hint a {
  color: var(--text);
}

.cookie-consent-modal__options {
  border-bottom: 1px solid var(--border);
}

.cookie-option {
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--border);
}

.cookie-option:last-child {
  border-bottom: none;
}

.cookie-option__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 0.45rem;
}

.cookie-option__title {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.cookie-option__badge {
  font-family: "Syne Mono", ui-monospace, monospace;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.cookie-option__desc {
  margin: 0;
  color: var(--text-muted);
  font-size: 0.9rem;
  line-height: 1.5;
}

.cookie-option__label {
  cursor: pointer;
}

.cookie-toggle {
  position: relative;
  display: inline-flex;
  flex-shrink: 0;
  cursor: pointer;
}

.cookie-toggle input {
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
  margin: 0;
}

.cookie-toggle__track {
  position: relative;
  display: block;
  width: 44px;
  height: 24px;
  border: 1px solid var(--border);
  background: var(--bg-elevated);
  transition: background 0.15s ease, border-color 0.15s ease;
}

.cookie-toggle__track::after {
  content: "";
  position: absolute;
  top: 4px;
  left: 4px;
  width: 14px;
  height: 14px;
  background: var(--border-strong);
  transition: transform 0.15s ease, background 0.15s ease;
}

.cookie-toggle input:checked + .cookie-toggle__track {
  border-color: var(--border-hover);
  background: var(--surface-hover-strong);
}

.cookie-toggle input:checked + .cookie-toggle__track::after {
  transform: translateX(20px);
  background: var(--text);
}

.cookie-toggle input:focus-visible + .cookie-toggle__track {
  outline: 2px solid var(--text);
  outline-offset: 2px;
}

.cookie-consent-modal__actions {
  justify-content: flex-end;
}

.footer__link-btn {
  padding: 0;
  border: none;
  background: none;
  color: inherit;
  font: inherit;
  text-decoration: underline;
  text-underline-offset: 0.15em;
  cursor: pointer;
}

.footer__link-btn:hover {
  color: var(--text);
}

.legal-page {
  max-width: none;
  margin: 0;
  padding: 0 var(--page-pad) var(--page-pad);
  border-bottom: 1px solid var(--border);
}

.legal-page__header .legal-page__lead {
  margin: 0.75rem 0 0;
  max-width: 60ch;
  color: var(--text-muted);
  line-height: 1.6;
}

.legal-page__nav {
  margin: 1rem 0 0;
  font-size: 0.9rem;
  color: var(--text-muted);
}

.legal-page__nav a {
  color: var(--text);
}

.legal-page__block {
  padding: 1.25rem 0;
  border-bottom: 1px solid var(--border);
}

.legal-page__block:last-child {
  border-bottom: none;
}

.legal-page__block h2 {
  margin: 0 0 0.65rem;
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.legal-page__block p {
  margin: 0 0 0.75rem;
  max-width: 65ch;
  color: var(--border-focus);
  line-height: 1.65;
}

.legal-page__block p:last-child {
  margin-bottom: 0;
}

.legal-page__block a {
  color: var(--text);
}
