/* ═══════════════════════════════════════════
   Settings Pages — Hub, profile, members,
   invites, tags, groups, trash.
   ═══════════════════════════════════════════ */

/* ─── Settings Layout (sidebar + content) ─── */
.settings-layout {
  max-width: 100%;
  margin: 0 auto;
  padding: 0px;
  display: flex;
  gap: 0px;
  align-items: flex-start;
}

/* ─── Sidebar Nav ─── */
.settings-nav {
  width: 200px;
  flex-shrink: 0;
  position: sticky;
  top: calc(var(--sc-nav-height) + 24px);
}

.settings-nav__list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 0;
  margin: 0;
}

.settings-nav__item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 10px;
  font-family: var(--sc-font-ui);
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--sc-bark-faint);
  text-decoration: none;
  transition: background 0.15s, color 0.15s;
}

.settings-nav__item:hover {
  background: var(--sc-cream-dark);
  color: var(--sc-bark);
}

.settings-nav__item.active {
  background: rgba(184, 96, 63, 0.08);
  color: var(--sc-rust);
}

.settings-nav__item svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  flex-shrink: 0;
}

/* ─── Content Area ─── */
.settings-content {
  flex: 1;
  min-width: 0;
}

/* ─── Settings Hub ─── */
.settings-hub {
  max-width: var(--sc-content-max);
  margin: 0 auto;
  padding: 0 24px 80px;
}

.settings-hub__header {
  margin-bottom: 32px;
}

.settings-hub__title {
  font-family: var(--sc-font-display);
  font-size: clamp(1.6rem, 4vw, 2rem);
  font-weight: 400;
  color: var(--sc-charcoal);
  margin-bottom: 6px;
}

.settings-hub__desc {
  font-family: var(--sc-font-ui);
  font-size: 0.9rem;
  color: var(--sc-text-secondary);
  line-height: 1.5;
}

/* ─── Card Grid ─── */
.settings-card-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}

.settings-card {
  background: var(--sc-warm-white);
  border: 1px solid var(--sc-border);
  border-radius: 14px;
  padding: 22px 20px;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
  transition: border-color 0.2s, box-shadow 0.2s;
  display: flex;
  align-items: center;
  gap: 16px;
}

.settings-card:hover {
  border-color: var(--sc-sand);
  box-shadow: 0 4px 16px rgba(90, 64, 50, 0.07);
}

.settings-card--disabled {
  opacity: 0.55;
  cursor: default;
  pointer-events: none;
}

.settings-card__icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: rgba(184, 96, 63, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.settings-card__icon .icon,
.settings-card__icon svg {
  width: 18px;
  height: 18px;
  stroke: var(--sc-rust);
  fill: none;
  stroke-width: 2;
}

.settings-card__body {
  flex: 1;
  min-width: 0;
}

.settings-card__title {
  font-family: var(--sc-font-ui);
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--sc-bark);
  display: flex;
  align-items: center;
  gap: 8px;
}

.settings-card__badge {
  font-family: var(--sc-font-ui);
  font-size: 0.68rem;
  font-weight: 500;
  color: var(--sc-text-tertiary);
  background: var(--sc-cream-dark);
  padding: 2px 8px;
  border-radius: 8px;
}

.settings-card__desc {
  font-family: var(--sc-font-ui);
  font-size: 0.78rem;
  color: var(--sc-text-tertiary);
  line-height: 1.5;
  margin-top: 2px;
}

.settings-card-meta {
  font-family: var(--sc-font-ui);
  font-size: 0.72rem;
  color: var(--sc-text-tertiary);
  margin-top: 4px;
}

/* ─── Overview Section ─── */
.settings-hub__overview {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: 32px;
}

.settings-hub__overview-card {
  background: var(--sc-warm-white);
  border: 1px solid var(--sc-border);
  border-radius: 14px;
  padding: 20px;
}

.settings-hub__overview-label {
  font-family: var(--sc-font-ui);
  font-size: 0.68rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--sc-text-tertiary);
  margin-bottom: 10px;
}

/* ─── Settings Forms ─── */
.settings-form {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.settings-actions {
  display: flex;
  gap: 10px;
  margin-top: 12px;
}

/* ─── Settings Page Header ─── */
.settings-header {
  margin-bottom: 24px;
}

.settings-header h1 {
  font-family: var(--sc-font-display);
  font-size: 1.5rem;
  color: var(--sc-charcoal);
  margin: 0;
}

.settings-header__count {
  font-family: var(--sc-font-ui);
  font-size: 0.82rem;
  color: var(--sc-text-tertiary);
}

.settings-header__desc {
  font-family: var(--sc-font-ui);
  font-size: 0.85rem;
  color: var(--sc-text-tertiary);
}

/* ─── Pending Requests ─── */
.settings-pending {
  background: rgba(180, 160, 60, 0.06);
  border: 1px solid rgba(180, 160, 60, 0.2);
  border-radius: 12px;
  padding: 18px 20px;
  margin-bottom: 20px;
}

.settings-pending__title {
  font-family: var(--sc-font-ui);
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--sc-status-in-progress);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.settings-pending__title svg { width: 16px; height: 16px; stroke: currentColor; fill: none; }

.settings-pending__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 0;
}

.settings-pending__identity { display: flex; align-items: center; gap: 12px; }

.settings-pending__avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--sc-font-ui);
  font-weight: 600;
  font-size: 0.82rem;
  color: white;
  flex-shrink: 0;
}

.settings-pending__info { display: flex; flex-direction: column; gap: 2px; }
.settings-pending__name { font-family: var(--sc-font-ui); font-size: 0.88rem; font-weight: 600; color: var(--sc-bark); }
.settings-pending__meta { font-family: var(--sc-font-ui); font-size: 0.75rem; color: var(--sc-text-tertiary); }
.settings-pending__actions { display: flex; gap: 8px; flex-shrink: 0; flex-wrap: wrap; }

@media (max-width: 560px) {
  .settings-pending__item {
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
    padding: 12px 0;
    border-bottom: 1px solid rgba(180, 160, 60, 0.15);
  }
  .settings-pending__item:last-child {
    border-bottom: none;
    padding-bottom: 0;
  }
  .settings-pending__actions {
    justify-content: stretch;
  }
  .settings-pending__actions .btn {
    flex: 1;
    min-height: 44px;
    justify-content: center;
  }
}

/* ─── Family settings: members roster ───
   Uses .members-roster__* only — do NOT reuse .member-card here; a later generic
   .member-card block in this file was overriding grid layout and broke alignment. */

.members-roster {
  margin-top: 8px;
  /* Shared column template: header + body rows must match exactly */
  --mr-gap: 1rem;
  --mr-cols: minmax(11rem, 1.75fr) minmax(7.25rem, 1fr) 4.75rem minmax(4.5rem, max-content);
}

.members-roster__shell {
  display: flex;
  flex-direction: column;
}

.members-roster__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* Mobile: compact stacked cards */
.members-roster__grid-head {
  display: none;
}

.members-roster__mob-label {
  display: block;
  font-family: var(--sc-font-ui);
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--sc-text-tertiary);
  margin-bottom: 5px;
}

.members-roster__row {
  margin: 0;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid var(--sc-border-subtle);
  background: var(--sc-warm-white);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.members-roster__identity {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  min-width: 0;
}

.members-roster__avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--sc-font-ui);
  font-weight: 600;
  font-size: 0.88rem;
  color: var(--sc-text-inverse);
  flex-shrink: 0;
}

.members-roster__name-block {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.members-roster__name {
  font-family: var(--sc-font-ui);
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--sc-bark);
  line-height: 1.3;
  word-break: break-word;
}

.members-roster__you {
  font-weight: 500;
  color: var(--sc-text-tertiary);
  font-size: 0.78rem;
}

.members-roster__email {
  font-family: var(--sc-font-ui);
  font-size: 0.76rem;
  color: var(--sc-text-tertiary);
  line-height: 1.35;
  word-break: break-word;
}

.members-roster__role {
  min-width: 0;
}

.members-roster__role-form {
  display: block;
  margin: 0;
}

.members-roster__select {
  width: 100%;
  min-height: 44px;
  padding: 8px 10px;
  font-size: 0.86rem;
  border-radius: 8px;
}

.members-roster__badge {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: 0 12px;
  font-size: 0.8rem;
}

.members-roster__joined-wrap {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.members-roster__joined {
  font-family: var(--sc-font-ui);
  font-size: 0.82rem;
  color: var(--sc-bark-faint);
  font-variant-numeric: tabular-nums;
}

.members-roster__actions {
  display: flex;
  padding-top: 2px;
  border-top: 1px solid var(--sc-border-subtle);
}

/* No remove CTA for owner / self — hide strip on phones */
.members-roster__actions--empty {
  display: none;
  border: none;
  padding: 0;
}

.members-roster__remove {
  width: 100%;
  min-height: 44px;
  justify-content: center;
}

.members-roster__action-placeholder {
  display: none;
}

/* Tablet / desktop: flat directory, one line per member, columns line up with header */
@media (min-width: 768px) {
  .members-roster {
    --mr-cols: minmax(12rem, 2fr) minmax(8rem, 1fr) 5.25rem minmax(4.75rem, max-content);
  }

  .members-roster__shell {
    border: 1px solid var(--sc-border-subtle);
    border-radius: 12px;
    overflow: hidden;
    background: var(--sc-surface);
  }

  .members-roster__grid-head {
    display: grid;
    grid-template-columns: var(--mr-cols);
    column-gap: var(--mr-gap);
    align-items: end;
    padding: 10px 18px 8px;
    font-family: var(--sc-font-ui);
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color: var(--sc-text-tertiary);
    text-align: left;
    background: var(--sc-cream-dark);
    border-bottom: 1px solid var(--sc-border-subtle);
  }

  .members-roster__hcell--joined {
    text-align: left;
  }

  .members-roster__hcell--actions {
    text-align: right;
  }

  .members-roster__list {
    gap: 0;
    background: var(--sc-warm-white);
  }

  .members-roster__row {
    display: grid;
    grid-template-columns: var(--mr-cols);
    column-gap: var(--mr-gap);
    align-items: center;
    padding: 8px 18px;
    border: none;
    border-radius: 0;
    border-bottom: 1px solid var(--sc-border-subtle);
    gap: 0;
    row-gap: 0;
  }

  .members-roster__row:last-child {
    border-bottom: none;
  }

  .members-roster__row:hover {
    background: var(--sc-cream);
  }

  .members-roster__mob-label {
    display: none;
  }

  .members-roster__avatar {
    width: 32px;
    height: 32px;
    font-size: 0.78rem;
  }

  .members-roster__name {
    font-size: 0.86rem;
  }

  .members-roster__email {
    font-size: 0.72rem;
  }

  .members-roster__identity {
    align-items: center;
    gap: 10px;
  }

  .members-roster__role {
    min-width: 0;
    justify-self: start;
  }

  .members-roster__select {
    width: auto;
    min-width: 8.75rem;
    max-width: 100%;
    min-height: 34px;
    padding: 5px 8px;
    font-size: 0.78rem;
  }

  .members-roster__badge {
    min-height: 0;
    padding: 3px 9px;
    font-size: 0.74rem;
  }

  .members-roster__joined-wrap {
    justify-self: start;
    text-align: left;
  }

  .members-roster__joined {
    font-size: 0.78rem;
  }

  .members-roster__actions {
    border-top: none;
    padding-top: 0;
    justify-self: end;
    justify-content: flex-end;
  }

  .members-roster__actions--empty {
    display: flex;
    align-items: center;
    justify-content: flex-end;
  }

  .members-roster__action-placeholder {
    display: block;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip-path: inset(50%);
    white-space: nowrap;
  }

  .members-roster__remove {
    width: auto;
    min-height: 0;
    padding: 5px 8px;
    font-size: 0.76rem;
    white-space: nowrap;
  }
}

@media (min-width: 1024px) {
  .members-roster {
    --mr-cols: minmax(14rem, 2.2fr) 10rem 5.5rem minmax(5rem, max-content);
  }

  .members-roster__grid-head,
  .members-roster__row {
    padding-left: 22px;
    padding-right: 22px;
  }
}

/* ─── Settings Sections (tags, groups sub-pages) ─── */
.settings-section {
  margin-bottom: 28px;
}

.settings-section-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 24px 0 12px;
}

.settings-section-head h2 {
  font-family: var(--sc-font-ui);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--sc-bark-faint);
  margin: 0;
}

.settings-section-count {
  font-family: var(--sc-font-ui);
  font-size: 0.68rem;
  font-weight: 600;
  background: var(--sc-cream-dark);
  color: var(--sc-text-tertiary);
  padding: 1px 7px;
  border-radius: 10px;
}

.settings-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* ─── Settings Page (profile sub-page) ─── */
.settings-page {
  max-width: var(--sc-content-max);
  margin: 0 auto;
  padding: 0 24px 80px;
  box-sizing: border-box;
}

/* Title row with actions (e.g. Tags + New tag) */
.settings-header--row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sc-space-md);
  flex-wrap: wrap;
}

/* ── Featured Image Upload ──────────────────────────────────────────────── */

.settings-featured-image__preview {
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  aspect-ratio: 21 / 9;
  background: var(--sc-cream-dark);
}

.settings-featured-image__preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.settings-featured-image__overlay {
  position: absolute;
  inset: 0;
  background: rgba(58, 53, 48, 0);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sc-space-sm);
  transition: background var(--sc-transition-fast);
}

.settings-featured-image__overlay .btn {
  opacity: 0;
  transform: translateY(4px);
  transition: opacity var(--sc-transition-fast), transform var(--sc-transition-fast);
}

.settings-featured-image__preview:hover .settings-featured-image__overlay {
  background: rgba(58, 53, 48, 0.45);
}

.settings-featured-image__preview:hover .settings-featured-image__overlay .btn {
  opacity: 1;
  transform: translateY(0);
}

.settings-featured-image__dropzone {
  border: 2px dashed var(--sc-border);
  border-radius: 14px;
  padding: 32px 24px;
  text-align: center;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sc-space-sm);
  transition: border-color var(--sc-transition-fast), background var(--sc-transition-fast);
}

.settings-featured-image__dropzone:hover {
  border-color: var(--sc-rust-soft);
  background: rgba(184, 96, 63, 0.02);
}

.settings-featured-image__dropzone svg {
  width: 36px;
  height: 36px;
  stroke: var(--sc-text-tertiary);
  fill: none;
  opacity: 0.5;
}

.settings-featured-image__dropzone-title {
  font-family: var(--sc-font-ui);
  font-size: 0.88rem;
  font-weight: var(--sc-weight-medium);
  color: var(--sc-bark);
  display: block;
}

.settings-featured-image__dropzone-hint {
  font-family: var(--sc-font-ui);
  font-size: 0.75rem;
  color: var(--sc-text-tertiary);
  display: block;
}

/* ── Family URL Display ────────────────────────────────────────────────── */

.settings-slug-display {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--sc-cream);
  border: 1px solid var(--sc-border-subtle);
  border-radius: var(--sc-radius-md);
  padding: 10px 14px;
}

.settings-slug-display svg {
  width: 16px;
  height: 16px;
  stroke: var(--sc-text-tertiary);
  fill: none;
  flex-shrink: 0;
}

.settings-slug-display code {
  font-family: var(--sc-font-ui);
  font-size: var(--sc-text-sm);
  color: var(--sc-text-tertiary);
}

.settings-slug-display code strong {
  color: var(--sc-bark);
  font-weight: var(--sc-weight-semibold);
}

.settings-form__hint {
  font-family: var(--sc-font-ui);
  font-size: 0.75rem;
  color: var(--sc-text-tertiary);
  margin-top: 4px;
}

/* ─── Alert Banners ─── */
.alert {
  font-family: var(--sc-font-ui);
  font-size: 0.85rem;
  padding: 12px 16px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.alert-error {
  background: rgba(192, 57, 43, 0.06);
  border: 1px solid rgba(192, 57, 43, 0.15);
  color: var(--sc-error);
}

.alert-success {
  background: rgba(107, 127, 94, 0.06);
  border: 1px solid rgba(107, 127, 94, 0.15);
  color: var(--sc-sage);
}

.alert-warning {
  background: rgba(180, 160, 60, 0.06);
  border: 1px solid rgba(180, 160, 60, 0.2);
  color: var(--sc-status-in-progress);
}

.alert-info {
  background: rgba(90, 64, 50, 0.04);
  border: 1px solid rgba(90, 64, 50, 0.1);
  color: var(--sc-bark-faint);
}

/* ─── Responsive ─── */
@media (max-width: 768px) {
  .settings-card-grid { grid-template-columns: 1fr; }
  .settings-hub__overview { grid-template-columns: 1fr; }
  .settings-hub { padding: 20px 16px 80px; }

  .settings-nav {
    width: 100%;
    position: static;
    margin-bottom: 20px;
  }

  .settings-nav__list {
    flex-direction: row;
    overflow-x: auto;
    gap: 4px;
    -webkit-overflow-scrolling: touch;
  }

  .settings-nav__item {
    padding: 8px 12px;
    font-size: 0.78rem;
    white-space: nowrap;
  }

  .settings-nav__item span { display: inline; }

  .members-roster {
    margin-left: -4px;
    margin-right: -4px;
  }
}

/* ══════════════════════════════════════════════════════════════════════════
   Settings: Trash
   ══════════════════════════════════════════════════════════════════════════ */

.settings-info-banner {
	display: flex;
	align-items: center;
	gap: var(--sc-space-sm);
	padding: 12px 16px;
	border-radius: var(--sc-radius-md);
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	color: var(--sc-bark-faint);
	background: var(--sc-cream-dark);
	border: 1px solid var(--sc-border-subtle);
	margin-bottom: var(--sc-space-lg);
}

.settings-info-banner svg {
	width: 18px;
	height: 18px;
	flex-shrink: 0;
	color: var(--sc-bark-faint);
}

.settings-trash-list {
	display: flex;
	flex-direction: column;
	gap: var(--sc-space-sm);
}

.trash-item {
	display: flex;
	align-items: center;
	gap: var(--sc-space-md);
	padding: 14px 16px;
	background: var(--sc-surface);
	border: var(--sc-border-width) solid var(--sc-border-subtle);
	border-radius: var(--sc-radius-md);
	transition: border-color var(--sc-transition-fast);
}

.trash-item:hover {
	border-color: var(--sc-sand);
}

.trash-item__icon {
	flex-shrink: 0;
	width: 20px;
	height: 20px;
	color: var(--sc-text-tertiary);
}

.trash-item__icon svg {
	width: 100%;
	height: 100%;
}

.trash-item__body {
	flex: 1;
	min-width: 0;
}

.trash-item__title {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	font-weight: var(--sc-weight-medium);
	color: var(--sc-bark);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.trash-item__meta {
	font-family: var(--sc-font-ui);
	font-size: 0.72rem;
	color: var(--sc-text-tertiary);
	margin-top: 2px;
}

.trash-item__badge {
	flex-shrink: 0;
	font-family: var(--sc-font-ui);
	font-size: 0.68rem;
	font-weight: var(--sc-weight-medium);
	color: var(--sc-bark-faint);
	background: var(--sc-cream-dark);
	padding: 3px 8px;
	border-radius: var(--sc-radius-full);
	white-space: nowrap;
}

.trash-item__actions {
	display: flex;
	gap: 6px;
	flex-shrink: 0;
}

@media (max-width: 640px) {
	.trash-item {
		flex-wrap: wrap;
		gap: var(--sc-space-sm);
	}

	.trash-item__badge {
		order: 3;
	}

	.trash-item__actions {
		order: 4;
		width: 100%;
	}
}

/* ══════════════════════════════════════════════════════════════════════════
   Settings: Invites
   ══════════════════════════════════════════════════════════════════════════ */

/* ── Join Link Card ────────────────────────────────────────────────────── */

.invites-join-link-card {
	background: var(--sc-surface);
	border: var(--sc-border-width) solid var(--sc-border);
	border-radius: 14px;
	padding: var(--sc-space-lg);
}

.invites-join-link-card__header {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	margin-bottom: 20px;
}

.invites-join-link-card__icon {
	width: 42px;
	height: 42px;
	border-radius: 12px;
	background: rgba(184, 96, 63, 0.08);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.invites-join-link-card__icon svg {
	width: 20px;
	height: 20px;
	stroke: var(--sc-rust);
	fill: none;
}

.invites-join-link-card__title-group {
	flex: 1;
	min-width: 0;
}

.invites-join-link-card__title {
	font-family: var(--sc-font-ui);
	font-size: 0.95rem;
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-bark);
	margin: 0;
}

.invites-join-link-card__desc {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	color: var(--sc-text-tertiary);
	margin: 4px 0 0;
}

.invites-join-link-card__toggle {
	display: flex;
	align-items: center;
	gap: 10px;
	flex-shrink: 0;
}

.invites-join-link-card__body {
	transition: opacity var(--sc-transition-fast);
}

.invites-join-link-card__link-row {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 14px;
}

.invites-join-link-card__link-box {
	flex: 1;
	min-width: 0;
	background: var(--sc-cream);
	border: 1px solid var(--sc-border-subtle);
	border-radius: var(--sc-radius-md);
	padding: 10px 14px;
	overflow: hidden;
}

.invites-join-link-card__link-box code {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	color: var(--sc-bark);
	word-break: break-all;
}

.invites-join-link-card__meta {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 12px;
}

.invites-join-link-card__meta-text {
	font-family: var(--sc-font-ui);
	font-size: 0.78rem;
	color: var(--sc-text-tertiary);
}

.invites-join-link-card__note {
	font-family: var(--sc-font-ui);
	font-size: 0.78rem;
	color: var(--sc-text-tertiary);
	line-height: 1.5;
	margin: 0;
}

/* ── Toggle Switch ─────────────────────────────────────────────────────── */

.toggle-switch {
	position: relative;
	display: inline-block;
	cursor: pointer;
}

.toggle-switch input {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
}

.toggle-switch__track {
	display: block;
	width: 40px;
	height: 22px;
	border-radius: 12px;
	background: var(--sc-cream-dark);
	border: 1px solid var(--sc-border);
	position: relative;
	transition: background var(--sc-transition-fast), border-color var(--sc-transition-fast);
}

.toggle-switch__track::after {
	content: '';
	position: absolute;
	top: 2px;
	left: 2px;
	width: 16px;
	height: 16px;
	border-radius: 50%;
	background: white;
	box-shadow: var(--sc-shadow-xs);
	transition: transform var(--sc-transition-fast);
}

.toggle-switch input:checked + .toggle-switch__track {
	background: var(--sc-sage);
	border-color: var(--sc-sage);
}

.toggle-switch input:checked + .toggle-switch__track::after {
	transform: translateX(18px);
}

.toggle-switch__label {
	font-family: var(--sc-font-ui);
	font-size: 0.78rem;
	font-weight: var(--sc-weight-medium);
	color: var(--sc-sage);
}

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

.invites-section-divider {
	height: 1px;
	background: var(--sc-border-subtle);
	margin: 28px 0;
}

/* ── Direct Invites ────────────────────────────────────────────────────── */

.invites-direct__send-row {
	display: flex;
	gap: 10px;
	align-items: flex-end;
	margin-bottom: var(--sc-space-lg);
}

.invites-direct__input-group {
	flex: 1;
	min-width: 0;
}

.invites-direct__list {
	display: flex;
	flex-direction: column;
}

.invites-direct__row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 12px 0;
	border-bottom: 1px solid var(--sc-border-subtle);
}

.invites-direct__row:last-child {
	border-bottom: none;
}

.invites-direct__row:hover {
	background: var(--sc-cream);
	margin: 0 -8px;
	padding-left: 8px;
	padding-right: 8px;
	border-radius: var(--sc-radius-sm);
}

.invites-direct__row--expired {
	opacity: 0.6;
}

.invites-direct__row-info {
	display: flex;
	align-items: center;
	gap: 14px;
	flex: 1;
	min-width: 0;
}

.invites-direct__email {
	font-family: var(--sc-font-ui);
	font-size: 0.88rem;
	font-weight: var(--sc-weight-medium);
	color: var(--sc-bark);
}

.invites-direct__row-meta {
	display: flex;
	align-items: center;
	gap: 8px;
}

.invites-direct__date {
	font-family: var(--sc-font-ui);
	font-size: 0.75rem;
	color: var(--sc-text-tertiary);
}

.invites-direct__row-actions {
	display: flex;
	gap: 8px;
	flex-shrink: 0;
}

.invites-direct__empty {
	text-align: center;
	padding: var(--sc-space-lg);
	color: var(--sc-text-tertiary);
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
}

/* ── Section Titles (shared) ───────────────────────────────────────────── */

.settings-section-title {
	font-family: var(--sc-font-ui);
	font-size: 0.88rem;
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-bark);
	margin: 0 0 6px;
}

.settings-explanation {
	font-family: var(--sc-font-ui);
	font-size: 0.88rem;
	color: var(--sc-text-secondary);
	line-height: 1.6;
	margin: 0 0 var(--sc-space-lg);
}

/* ── Invites Responsive ────────────────────────────────────────────────── */

@media (max-width: 640px) {
	.invites-join-link-card__header {
		flex-wrap: wrap;
	}

	.invites-join-link-card__link-row {
		flex-direction: column;
		align-items: stretch;
	}

	.invites-direct__row {
		flex-direction: column;
		align-items: flex-start;
		gap: 10px;
	}

	.invites-direct__row-info {
		flex-direction: column;
		align-items: flex-start;
		gap: 6px;
	}
}

/* ── Settings Hub Dashboard (V2) ────────────────────────────────────────── */

/* Library profile snapshot */
.settings-hub__profile {
	display: flex;
	gap: var(--sc-space-lg);
	align-items: flex-start;
	padding: var(--sc-space-lg);
	background: var(--sc-surface);
	border: 1px solid var(--sc-border-subtle);
	border-radius: var(--sc-radius-lg);
	box-shadow: var(--sc-shadow-xs);
	margin-bottom: var(--sc-space-lg);
}

.settings-hub__cover {
	width: 80px;
	height: 80px;
	border-radius: var(--sc-radius-md);
	object-fit: cover;
	flex-shrink: 0;
}

.settings-hub__cover--placeholder {
	background: linear-gradient(135deg, var(--sc-warm-1), var(--sc-warm-2));
	display: flex;
	align-items: center;
	justify-content: center;
}

.settings-hub__cover-monogram {
	width: 48px;
	height: 48px;
	font-size: var(--sc-text-lg);
}

.settings-hub__profile-info {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: var(--sc-space-xs);
}

.settings-hub__profile-name {
	font-family: var(--sc-font-display);
	font-size: var(--sc-text-xl);
	color: var(--sc-text-primary);
	line-height: var(--sc-leading-tight);
}

.settings-hub__profile-desc {
	font-family: var(--sc-font-body);
	font-size: var(--sc-text-sm);
	color: var(--sc-text-secondary);
	margin: 0;
}

.settings-hub__profile-meta {
	display: flex;
	gap: var(--sc-space-xs);
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	color: var(--sc-text-tertiary);
	flex-wrap: wrap;
}

/* Stats grid (6 stats) */
.settings-hub__stats-grid {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: var(--sc-space-sm);
	margin-bottom: var(--sc-space-lg);
}

.settings-hub__stat {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 2px;
	padding: var(--sc-space-md) var(--sc-space-sm);
	background: var(--sc-surface);
	border: 1px solid var(--sc-border-subtle);
	border-radius: var(--sc-radius-md);
	text-align: center;
}

.settings-hub__stat-value {
	font-family: var(--sc-font-display);
	font-size: var(--sc-text-xl);
	font-weight: var(--sc-weight-bold);
	color: var(--sc-text-primary);
	line-height: 1;
}

.settings-hub__stat-label {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	color: var(--sc-text-tertiary);
	text-transform: uppercase;
	letter-spacing: var(--sc-tracking-wide);
}

/* Section rows (2-column preview cards) */
.settings-hub__section-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--sc-space-md);
	margin-bottom: var(--sc-space-md);
}

.settings-hub__preview-card {
	display: flex;
	flex-direction: column;
	gap: var(--sc-space-sm);
	padding: var(--sc-space-md);
	background: var(--sc-surface);
	border: 1px solid var(--sc-border-subtle);
	border-radius: var(--sc-radius-lg);
	box-shadow: var(--sc-shadow-xs);
}

.settings-hub__preview-card-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--sc-space-sm);
}

.settings-hub__preview-title {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-text-primary);
}

.settings-hub__pending-badge {
	display: inline-flex;
	align-items: center;
	padding: 2px var(--sc-space-xs);
	background: var(--sc-warning-subtle);
	color: var(--sc-warning);
	font-family: var(--sc-font-ui);
	font-size: 11px;
	font-weight: var(--sc-weight-semibold);
	border-radius: var(--sc-radius-full);
}

.settings-hub__preview-card-foot {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: auto;
	padding-top: var(--sc-space-xs);
	border-top: 1px solid var(--sc-border-subtle);
}

.settings-hub__preview-count {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	color: var(--sc-text-tertiary);
}

.settings-hub__manage-link {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	font-weight: var(--sc-weight-medium);
	color: var(--sc-accent-text);
	text-decoration: none;
	transition: color var(--sc-transition-fast);
}

.settings-hub__manage-link:hover {
	color: var(--sc-accent-hover);
}

/* Avatar stack */
.settings-hub__avatar-stack {
	display: flex;
	flex-direction: row;
}

.settings-hub__avatar-item {
	width: 32px;
	height: 32px;
	font-size: var(--sc-text-xs);
	border-radius: var(--sc-radius-full);
	margin-left: -8px;
	border: 2px solid var(--sc-surface);
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--sc-font-ui);
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-text-inverse);
}

.settings-hub__avatar-item:first-child {
	margin-left: 0;
}

/* Invite status */
.settings-hub__invite-status {
	display: flex;
	align-items: center;
	gap: var(--sc-space-xs);
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	color: var(--sc-text-secondary);
	flex: 1;
}

/* Tag pills preview */
.settings-hub__tag-pills {
	display: flex;
	flex-wrap: wrap;
	gap: var(--sc-space-xs);
}

.tag-pill--muted {
	background: var(--sc-surface);
	color: var(--sc-text-tertiary);
	border-color: var(--sc-border-subtle);
}

/* Trash status */
.settings-hub__trash-status {
	display: flex;
	align-items: center;
	gap: var(--sc-space-sm);
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	color: var(--sc-text-secondary);
	flex: 1;
}

.settings-hub__trash-status svg {
	color: var(--sc-text-tertiary);
	flex-shrink: 0;
}

.settings-hub__empty-hint {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	color: var(--sc-text-tertiary);
	margin: 0;
	flex: 1;
}

/* .settings-sidebar__badge lives in layout.css */

/* Responsive: stats grid collapse */
@media (max-width: 768px) {
	.settings-hub__stats-grid {
		grid-template-columns: repeat(3, 1fr);
	}

	.settings-hub__section-row {
		grid-template-columns: 1fr;
	}

	.settings-hub__profile {
		flex-direction: column;
	}

	.settings-hub__cover {
		width: 60px;
		height: 60px;
	}
}

/* ── Account Hub Dashboard ──────────────────────────────────────────────── */

.account-hub {
	display: flex;
	flex-direction: column;
	gap: var(--sc-space-xl);
}

.account-hub__profile {
	display: flex;
	gap: var(--sc-space-md);
	align-items: flex-start;
	padding: var(--sc-space-lg);
	background: var(--sc-surface);
	border: 1px solid var(--sc-border-subtle);
	border-radius: var(--sc-radius-lg);
	box-shadow: var(--sc-shadow-xs);
}

.account-hub__profile-avatar {
	width: 56px;
	height: 56px;
	border-radius: var(--sc-radius-full);
	object-fit: cover;
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-lg);
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-text-inverse);
}

.account-hub__profile-info {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.account-hub__profile-name {
	font-family: var(--sc-font-display);
	font-size: var(--sc-text-xl);
	color: var(--sc-text-primary);
	line-height: var(--sc-leading-tight);
}

.account-hub__profile-email {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	color: var(--sc-text-secondary);
}

.account-hub__profile-meta {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	color: var(--sc-text-tertiary);
}

.account-hub__section {
	display: flex;
	flex-direction: column;
	gap: var(--sc-space-sm);
}

.account-hub__section-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.account-hub__section-title {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	font-weight: var(--sc-weight-semibold);
	letter-spacing: var(--sc-tracking-wide);
	text-transform: uppercase;
	color: var(--sc-text-tertiary);
}

.account-hub__section-manage {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	font-weight: var(--sc-weight-medium);
	color: var(--sc-accent-text);
	text-decoration: none;
	transition: color var(--sc-transition-fast);
}

.account-hub__section-manage:hover {
	color: var(--sc-accent-hover);
}

/* Personal library card */
.account-hub__personal-card {
	display: flex;
	align-items: center;
	gap: var(--sc-space-md);
	padding: var(--sc-space-md) var(--sc-space-lg);
	background: var(--sc-surface);
	border: 1px solid var(--sc-border-subtle);
	border-radius: var(--sc-radius-lg);
	text-decoration: none;
	color: inherit;
	box-shadow: var(--sc-shadow-xs);
	transition: box-shadow var(--sc-transition-fast), border-color var(--sc-transition-fast);
}

.account-hub__personal-card:hover {
	box-shadow: var(--sc-shadow-sm);
	border-color: var(--sc-accent);
}

.account-hub__personal-icon {
	width: 40px;
	height: 40px;
	border-radius: var(--sc-radius-md);
	background: rgba(107, 127, 94, 0.1);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.account-hub__personal-icon svg {
	stroke: var(--sc-sage);
}

.account-hub__personal-body {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.account-hub__personal-title {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-text-primary);
}

.account-hub__personal-meta {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	color: var(--sc-text-tertiary);
}

/* Family list */
.account-hub__family-list {
	display: flex;
	flex-direction: column;
	gap: var(--sc-space-xs);
}

.account-hub__family-row {
	display: flex;
	align-items: center;
	gap: var(--sc-space-sm);
	padding: var(--sc-space-sm) var(--sc-space-md);
	background: var(--sc-surface);
	border: 1px solid var(--sc-border-subtle);
	border-radius: var(--sc-radius-md);
	text-decoration: none;
	color: inherit;
	transition: background var(--sc-transition-fast);
}

.account-hub__family-row:hover {
	background: var(--sc-accent-subtle);
}

.account-hub__family-avatar {
	width: 32px;
	height: 32px;
	font-size: var(--sc-text-sm);
	border-radius: var(--sc-radius-md);
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--sc-font-ui);
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-text-inverse);
}

.account-hub__family-name {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	font-weight: var(--sc-weight-medium);
	color: var(--sc-text-primary);
}

.account-hub__family-empty {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	color: var(--sc-text-tertiary);
	padding: var(--sc-space-sm) 0;
}

.account-hub__create-family {
	display: inline-flex;
	align-items: center;
	gap: var(--sc-space-xs);
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	color: var(--sc-accent-text);
	text-decoration: none;
	margin-top: var(--sc-space-xs);
	transition: color var(--sc-transition-fast);
}

.account-hub__create-family:hover {
	color: var(--sc-accent-hover);
}

/* Security status in hub */
.account-hub__security-list {
	display: flex;
	flex-direction: column;
	gap: 0;
	background: var(--sc-surface);
	border: 1px solid var(--sc-border-subtle);
	border-radius: var(--sc-radius-lg);
	overflow: hidden;
}

.account-hub__security-item {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--sc-space-sm) var(--sc-space-md);
	border-bottom: 1px solid var(--sc-border-subtle);
}

.account-hub__security-item:last-child {
	border-bottom: none;
}

.account-hub__security-label {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	color: var(--sc-text-secondary);
}

/* Danger zone */
.account-hub__danger-zone {
	border: 1px solid var(--sc-error-subtle);
	border-radius: var(--sc-radius-lg);
	padding: var(--sc-space-md) var(--sc-space-lg);
}

.account-hub__danger-title {
	color: var(--sc-error) !important;
}

.account-hub__danger-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--sc-space-md);
	margin-top: var(--sc-space-sm);
}

.account-hub__danger-name {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-text-primary);
}

.account-hub__danger-desc {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	color: var(--sc-text-tertiary);
	margin-top: 2px;
}

/* ── Security Status Indicators ─────────────────────────────────────────── */

.security-status--ok {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	font-weight: var(--sc-weight-medium);
	color: var(--sc-success);
}

.security-status--ok::before {
	content: '';
	display: inline-block;
	width: 7px;
	height: 7px;
	border-radius: var(--sc-radius-full);
	background: var(--sc-success);
	flex-shrink: 0;
}

.security-status--warn {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	font-weight: var(--sc-weight-medium);
	color: var(--sc-warning);
}

.security-status--warn::before {
	content: '';
	display: inline-block;
	width: 7px;
	height: 7px;
	border-radius: var(--sc-radius-full);
	background: var(--sc-warning);
	flex-shrink: 0;
}

/* ── Security Page ──────────────────────────────────────────────────────── */

.security-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--sc-space-xl);
	align-items: start;
}

.security-col {
	display: flex;
	flex-direction: column;
	gap: var(--sc-space-md);
}

.security-section {
	background: var(--sc-surface);
	border: 1px solid var(--sc-border-subtle);
	border-radius: var(--sc-radius-lg);
	overflow: hidden;
}

.security-section__header {
	display: flex;
	align-items: center;
	gap: var(--sc-space-sm);
	padding: var(--sc-space-md);
}

.security-section__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: var(--sc-radius-md);
	background: var(--sc-accent-subtle);
	flex-shrink: 0;
	color: var(--sc-accent-text);
}

.security-section__info {
	flex: 1;
	min-width: 0;
}

.security-section__title {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-text-primary);
	line-height: 1.3;
}

.security-section__value {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	color: var(--sc-text-tertiary);
	margin-top: 1px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.security-section__status {
	flex-shrink: 0;
}

.security-expand {
	padding: var(--sc-space-md);
	border-top: 1px solid var(--sc-border-subtle);
	background: var(--sc-bg);
	display: flex;
	flex-direction: column;
	gap: var(--sc-space-sm);
}

.security-expand__note {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	color: var(--sc-text-tertiary);
	margin: 0;
}

.security-expand__actions {
	display: flex;
	gap: var(--sc-space-sm);
	padding-top: var(--sc-space-xs);
}

.security-session {
	display: flex;
	align-items: center;
	gap: var(--sc-space-sm);
	padding: var(--sc-space-sm) var(--sc-space-md);
	border-top: 1px solid var(--sc-border-subtle);
}

.security-session__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: var(--sc-radius-sm);
	background: var(--sc-accent-subtle);
	flex-shrink: 0;
	color: var(--sc-accent-text);
}

.security-session__info {
	flex: 1;
}

.security-session__name {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	font-weight: var(--sc-weight-medium);
	color: var(--sc-text-primary);
}

.security-session__meta {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	color: var(--sc-text-tertiary);
}

.security-activity {
	padding: var(--sc-space-md);
	border-top: 1px solid var(--sc-border-subtle);
}

/* ── Profile Form Two-Column Grid ───────────────────────────────────────── */

.profile-form__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--sc-space-xl);
	align-items: start;
}

.profile-form__col {
	display: flex;
	flex-direction: column;
	gap: var(--sc-space-md);
}

@media (max-width: 860px) {
	.profile-form__grid {
		grid-template-columns: 1fr;
	}

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

/* ── Profile page ───────────────────────────────────────────────────────── */

.profile-page__title {
	font-family: var(--sc-font-display);
	font-size: var(--sc-text-2xl);
	color: var(--sc-text-primary);
	margin: var(--sc-space-md) 0 var(--sc-space-lg);
}

.profile-page__actions {
	display: flex;
	gap: var(--sc-space-sm);
	padding-top: var(--sc-space-lg);
	margin-top: var(--sc-space-sm);
}

/* Profile cards — one card per section */
.profile-card {
	background: var(--sc-surface);
	border: 1px solid var(--sc-border-subtle);
	border-radius: var(--sc-radius-lg);
	padding: var(--sc-space-lg);
	display: flex;
	flex-direction: column;
	gap: var(--sc-space-md);
}

.profile-card__title {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	font-weight: var(--sc-weight-semibold);
	letter-spacing: var(--sc-tracking-wide);
	text-transform: uppercase;
	color: var(--sc-text-tertiary);
	padding-bottom: var(--sc-space-sm);
	border-bottom: 1px solid var(--sc-border-subtle);
}

.profile-card__desc {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	color: var(--sc-text-secondary);
	margin: 0;
}

.profile-card__label {
	display: block;
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	font-weight: var(--sc-weight-semibold);
	letter-spacing: var(--sc-tracking-wide);
	text-transform: uppercase;
	color: var(--sc-text-secondary);
	margin-bottom: var(--sc-space-xs);
}

.profile-card__required {
	color: var(--sc-error);
}

.profile-card__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--sc-space-sm);
}

/* Photo section */
.profile-card__photo-row {
	display: flex;
	align-items: center;
	gap: var(--sc-space-md);
}

.profile-card__avatar {
	width: 64px;
	height: 64px;
	border-radius: var(--sc-radius-full);
	object-fit: cover;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-lg);
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-text-inverse);
	flex-shrink: 0;
}

.profile-card__photo-actions {
	display: flex;
	align-items: center;
	gap: var(--sc-space-sm);
	flex-wrap: wrap;
}

.profile-card__photo-hint {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	color: var(--sc-text-tertiary);
	width: 100%;
}

/* Connected characters */
.profile-card__char-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--sc-space-xs);
}

.profile-card__char-row {
	display: flex;
	align-items: center;
	gap: var(--sc-space-sm);
	padding: var(--sc-space-sm) var(--sc-space-md);
	background: var(--sc-bg);
	border: 1px solid var(--sc-border-subtle);
	border-radius: var(--sc-radius-md);
}

.profile-card__char-avatar {
	width: 36px;
	height: 36px;
	font-size: var(--sc-text-sm);
	border-radius: var(--sc-radius-full);
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--sc-font-ui);
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-text-inverse);
}

.profile-card__char-info {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 1px;
}

.profile-card__char-name {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-text-primary);
}

.profile-card__char-family {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	color: var(--sc-text-tertiary);
}

.profile-card__char-view {
	display: inline-flex;
	align-items: center;
	gap: 3px;
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	font-weight: var(--sc-weight-medium);
	color: var(--sc-accent-text);
	text-decoration: none;
	flex-shrink: 0;
	transition: color var(--sc-transition-fast);
}

.profile-card__char-view:hover {
	color: var(--sc-accent-hover);
	text-decoration: none;
}

/* Email row with verified badge */
.profile-card__email-row {
	display: flex;
	align-items: center;
	gap: var(--sc-space-sm);
}

.profile-card__email-row .form-input {
	flex: 1;
}

.profile-card__verified-badge {
	display: inline-flex;
	align-items: center;
	padding: 3px var(--sc-space-xs);
	background: var(--sc-success-subtle);
	color: var(--sc-success);
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	font-weight: var(--sc-weight-semibold);
	border-radius: var(--sc-radius-sm);
	white-space: nowrap;
	flex-shrink: 0;
}

/* Ghost button variant */
.btn--ghost {
	background: transparent;
	border-color: transparent;
	color: var(--sc-text-secondary);
}

.btn--ghost:hover {
	background: var(--sc-accent-subtle);
	color: var(--sc-accent-text);
}

/* ── Settings page header (title + subtitle) ────────────────────────────── */

.settings-header__title {
	font-family: var(--sc-font-display);
	font-size: clamp(1.5rem, 4vw, 1.9rem);
	font-weight: var(--sc-weight-normal);
	color: var(--sc-charcoal);
	margin: 0 0 6px;
}

.settings-header__desc {
	font-family: var(--sc-font-ui);
	font-size: 0.9rem;
	color: var(--sc-text-secondary);
	margin: 0;
}

/* ── Account settings dashboard ─────────────────────────────────────────── */

/* Profile snapshot */
.dash-profile {
	display: flex;
	align-items: center;
	gap: var(--sc-space-md);
	padding: var(--sc-space-lg);
	background: var(--sc-surface);
	border: 1px solid var(--sc-border-subtle);
	border-radius: var(--sc-radius-lg);
	box-shadow: var(--sc-shadow-xs);
	margin-bottom: var(--sc-space-xl);
}

.dash-profile__avatar {
	width: 56px;
	height: 56px;
	border-radius: var(--sc-radius-full);
	object-fit: cover;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-lg);
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-text-inverse);
	flex-shrink: 0;
}

.dash-profile__info {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 3px;
}

.dash-profile__name {
	font-family: var(--sc-font-display);
	font-size: var(--sc-text-xl);
	color: var(--sc-text-primary);
	line-height: var(--sc-leading-tight);
}

.dash-profile__email {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	color: var(--sc-text-secondary);
}

.dash-profile__meta {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	color: var(--sc-text-tertiary);
}

.dash-profile__edit {
	display: inline-flex;
	align-items: center;
	gap: var(--sc-space-xs);
	padding: 8px var(--sc-space-md);
	border: 1px solid var(--sc-border-subtle);
	border-radius: var(--sc-radius-md);
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	font-weight: var(--sc-weight-medium);
	color: var(--sc-text-secondary);
	text-decoration: none;
	background: var(--sc-surface);
	transition: background var(--sc-transition-fast), border-color var(--sc-transition-fast), color var(--sc-transition-fast);
	flex-shrink: 0;
}

.dash-profile__edit:hover {
	background: var(--sc-accent-subtle);
	border-color: var(--sc-accent);
	color: var(--sc-accent-text);
}

/* Plans section header */
.dash-section {
	margin-bottom: var(--sc-space-md);
}

.dash-section__title {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	font-weight: var(--sc-weight-semibold);
	letter-spacing: var(--sc-tracking-wide);
	text-transform: uppercase;
	color: var(--sc-text-tertiary);
}

/* Plans grid */
.dash-plans {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--sc-space-md);
}

.dash-plan-card {
	background: var(--sc-warm-white);
	border: 1px solid var(--sc-border);
	border-radius: var(--sc-radius-lg);
	padding: var(--sc-space-lg);
	display: flex;
	flex-direction: column;
	gap: var(--sc-space-md);
}

.dash-plan-card--empty {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: var(--sc-space-sm);
	min-height: 160px;
	border-style: dashed;
}

.dash-plan-card__empty-title {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	color: var(--sc-text-tertiary);
}

.dash-plan-card__header {
	display: flex;
	align-items: center;
	gap: var(--sc-space-sm);
}

.dash-plan-card__icon {
	width: 36px;
	height: 36px;
	border-radius: var(--sc-radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.dash-plan-card__icon--personal {
	background: rgba(107, 127, 94, 0.1);
	color: var(--sc-sage);
}

.dash-plan-card__icon--family {
	background: rgba(184, 96, 63, 0.08);
	color: var(--sc-rust);
}

.dash-plan-card__plan-info {
	flex: 1;
	min-width: 0;
}

.dash-plan-card__label {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	color: var(--sc-text-tertiary);
	text-transform: uppercase;
	letter-spacing: var(--sc-tracking-wide);
}

.dash-plan-card__name {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-base);
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-text-primary);
}

.dash-plan-card__badge {
	display: inline-flex;
	align-items: center;
	padding: 3px 10px;
	border-radius: var(--sc-radius-full);
	background: var(--sc-success-subtle);
	color: var(--sc-success);
	font-family: var(--sc-font-ui);
	font-size: 11px;
	font-weight: var(--sc-weight-semibold);
	flex-shrink: 0;
}

.dash-plan-card__badge--family {
	background: var(--sc-accent-subtle);
	color: var(--sc-accent-text);
}

/* Usage bars */
.dash-plan-card__usage {
	display: flex;
	flex-direction: column;
	gap: 4px;
	flex: 1;
}

.dash-usage-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.dash-usage-row__label {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	color: var(--sc-text-secondary);
}

.dash-usage-row__value {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-text-primary);
}

.dash-usage-row__value span {
	font-weight: var(--sc-weight-normal);
	color: var(--sc-text-tertiary);
}

.dash-usage-bar {
	height: 6px;
	background: var(--sc-cream-dark);
	border-radius: var(--sc-radius-full);
	overflow: hidden;
}

.dash-usage-bar__fill {
	height: 100%;
	border-radius: var(--sc-radius-full);
	background: var(--sc-rust-soft);
	transition: width 0.4s var(--sc-ease-out);
}

.dash-usage-bar__fill--sage {
	background: var(--sc-sage-light);
}

.dash-usage-bar__fill--moss {
	background: var(--sc-moss);
}

.dash-plan-card__addon {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	color: var(--sc-text-tertiary);
	margin-top: 2px;
}

.dash-plan-card__link {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	font-weight: var(--sc-weight-medium);
	color: var(--sc-accent-text);
	text-decoration: none;
	margin-top: auto;
	padding-top: var(--sc-space-sm);
	border-top: 1px solid var(--sc-border-subtle);
	transition: color var(--sc-transition-fast);
}

.dash-plan-card__link:hover {
	color: var(--sc-accent-hover);
}

/* Generic dashboard card */
.dash-card {
	background: var(--sc-surface);
	border: 1px solid var(--sc-border-subtle);
	border-radius: var(--sc-radius-lg);
	overflow: hidden;
}

.dash-card__header {
	display: flex;
	align-items: center;
	gap: var(--sc-space-sm);
	padding: var(--sc-space-md) var(--sc-space-lg);
	border-bottom: 1px solid var(--sc-border-subtle);
}

.dash-card__title {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-text-primary);
}

.dash-card__header svg {
	color: var(--sc-text-secondary);
	flex-shrink: 0;
}

.dash-card__manage {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	margin-left: auto;
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	font-weight: var(--sc-weight-medium);
	color: var(--sc-accent-text);
	text-decoration: none;
	transition: color var(--sc-transition-fast);
}

.dash-card__manage:hover {
	color: var(--sc-accent-hover);
}

/* Security status list — horizontal 3-column */
.dash-security-list {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	padding: var(--sc-space-md) var(--sc-space-lg);
	gap: var(--sc-space-md);
}

.dash-security-item {
	display: flex;
	align-items: flex-start;
	gap: var(--sc-space-sm);
}

.dash-security-item__dot {
	width: 10px;
	height: 10px;
	border-radius: var(--sc-radius-full);
	flex-shrink: 0;
	margin-top: 3px;
}

.dash-security-item__dot--good {
	background: var(--sc-success);
}

.dash-security-item__dot--warn {
	background: var(--sc-warning);
}

.dash-security-item__info {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.dash-security-item__label {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	font-weight: var(--sc-weight-medium);
	color: var(--sc-text-primary);
}

.dash-security-item__detail {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-xs);
	color: var(--sc-text-tertiary);
}

@media (max-width: 768px) {
	.dash-plans {
		grid-template-columns: 1fr;
	}

	.dash-security-list {
		grid-template-columns: 1fr;
	}
}

/* ── Family settings hub (V2 mockup alignment) ─────────────────────────── */

.settings-header__top {
	margin: 0;
}

.dash-profile--family {
	margin-bottom: var(--sc-space-lg);
}

.dash-profile__avatar-img {
	width: 72px;
	height: 72px;
	border-radius: var(--sc-radius-full);
	overflow: hidden;
	flex-shrink: 0;
	border: 1px solid var(--sc-border-subtle);
}

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

.dash-profile--family .dash-profile__avatar {
	width: 72px;
	height: 72px;
	font-size: var(--sc-text-2xl);
}

.settings-hub__library-card {
	margin-top: var(--sc-space-lg);
}

.settings-hub__library-card .lib-stats-card {
	padding: var(--sc-space-md) var(--sc-space-lg) var(--sc-space-lg);
}

.lib-stats-card__storage--compact .lib-stats-card__storage-header {
	margin-bottom: 0;
}

.lib-stats-card__storage-value--link {
	font-size: 0.95rem;
	font-weight: 600;
}

.lib-stats-card__storage-value--link a {
	color: var(--sc-accent-text);
	text-decoration: none;
	font-weight: 600;
}

.lib-stats-card__storage-value--link a:hover {
	text-decoration: underline;
}

.settings-hub__lib-stats-grid {
	margin-top: var(--sc-space-sm);
}

.settings-hub .dash-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--sc-space-md);
	margin-top: var(--sc-space-md);
}

.settings-hub .dash-row > .dash-card {
	display: flex;
	flex-direction: column;
	min-height: 240px;
}

.settings-hub .dash-row .dash-members-summary {
	padding: var(--sc-space-md) var(--sc-space-lg) 0;
	flex: 1;
}

.settings-hub .dash-row .dash-members-summary__pending {
	padding: 0 var(--sc-space-lg) var(--sc-space-sm);
	margin-top: 4px;
}

.settings-hub .dash-row .dash-invites-list {
	padding: var(--sc-space-md) var(--sc-space-lg);
	flex: 1;
}

.settings-hub .dash-row .dash-tags-preview {
	padding: var(--sc-space-md) var(--sc-space-lg) var(--sc-space-sm);
	flex: 1;
	min-height: 72px;
}

.settings-hub .dash-row .dash-trash-summary {
	padding: var(--sc-space-md) var(--sc-space-lg) var(--sc-space-sm);
	flex: 1;
}

.settings-hub .dash-row .settings-hub__empty-hint {
	padding: var(--sc-space-md) var(--sc-space-lg);
	margin: 0;
}


.dash-members-summary {
	margin-bottom: 0;
}

.dash-members-summary__avatars {
	display: flex;
	margin-bottom: 10px;
}

.dash-member-avatar {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--sc-font-ui);
	font-weight: 600;
	font-size: 0.72rem;
	color: var(--sc-text-inverse);
	border: 2px solid var(--sc-surface);
	margin-left: -8px;
}

.dash-member-avatar:first-child {
	margin-left: 0;
}

.dash-member-avatar--more {
	background: var(--sc-cream-dark);
	color: var(--sc-text-secondary);
	font-size: 0.68rem;
}

.dash-members-summary__breakdown {
	font-family: var(--sc-font-ui);
	font-size: 0.78rem;
	color: var(--sc-text-secondary);
}

.dash-members-summary__pending {
	display: flex;
	align-items: center;
	gap: 8px;
	font-family: var(--sc-font-ui);
	font-size: 0.82rem;
	font-weight: 500;
	color: var(--sc-warning);
}

.dash-members-summary__pending-dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--sc-warning);
	flex-shrink: 0;
}

.dash-invites-list {
	display: flex;
	flex-direction: column;
	gap: 0;
}

.dash-invite-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--sc-space-sm);
	padding: 10px 0;
	border-bottom: 1px solid var(--sc-border-subtle);
}

.dash-invite-row:last-child {
	border-bottom: none;
}

.dash-invite-row__info {
	flex: 1;
	min-width: 0;
}

.dash-invite-row__name {
	font-family: var(--sc-font-ui);
	font-size: 0.85rem;
	font-weight: 500;
	color: var(--sc-text-primary);
}

.dash-invite-row__detail {
	font-family: var(--sc-font-ui);
	font-size: 0.72rem;
	color: var(--sc-text-tertiary);
	margin-top: 2px;
}

.dash-tags-preview {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-content: flex-start;
}

.dash-tag {
	font-family: var(--sc-font-ui);
	font-size: 0.78rem;
	font-weight: 500;
	color: var(--sc-text-primary);
	background: var(--sc-cream);
	border: 1px solid var(--sc-border-subtle);
	border-radius: 8px;
	padding: 5px 12px;
}

.dash-tag--more {
	color: var(--sc-text-tertiary);
	background: transparent;
	border-style: dashed;
}

.dash-trash-summary {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.dash-trash-summary__count {
	font-family: var(--sc-font-ui);
	font-size: 0.88rem;
	color: var(--sc-text-secondary);
}

.dash-trash-summary__count strong {
	font-weight: 700;
	color: var(--sc-text-primary);
	font-size: 1.1rem;
}

.dash-trash-summary__detail {
	font-family: var(--sc-font-ui);
	font-size: 0.75rem;
	color: var(--sc-text-tertiary);
}

.dash-card__link {
	display: flex;
	align-items: center;
	gap: 4px;
	font-family: var(--sc-font-ui);
	font-size: 0.82rem;
	font-weight: 500;
	color: var(--sc-accent-text);
	text-decoration: none;
	margin-top: auto;
	padding: var(--sc-space-md) var(--sc-space-lg);
	border-top: 1px solid var(--sc-border-subtle);
	transition: color var(--sc-transition-fast);
}

.dash-card__link:hover {
	color: var(--sc-accent-hover);
}

.dash-card__link svg {
	flex-shrink: 0;
}

@media (max-width: 768px) {
	.settings-hub .dash-row {
		grid-template-columns: 1fr;
	}

	.settings-hub__lib-stats-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* ── Sharing groups (settings) — V2 mockup alignment ─────────────────────── */

.settings-page--groups {
	max-width: var(--sc-content-max);
	margin: 0 auto;
	padding: 24px 24px 80px;
}

.settings-page--groups .settings-header {
	margin-bottom: 0;
}

.settings-page--groups .settings-header__title {
	font-family: var(--sc-font-display);
	font-size: var(--sc-text-2xl);
	font-weight: var(--sc-weight-normal);
	color: var(--sc-text-primary);
	margin: 0;
}

/* Intro (account__groups-intro) */
.account__groups-intro {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	margin-bottom: 24px;
	margin-top: 20px;
	padding: 18px 22px;
	background: rgba(107, 127, 94, 0.05);
	border: 1px solid rgba(107, 127, 94, 0.12);
	border-radius: 14px;
}

.account__groups-intro-icon {
	width: 40px;
	height: 40px;
	border-radius: 12px;
	background: rgba(107, 127, 94, 0.12);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.account__groups-intro-icon svg {
	width: 20px;
	height: 20px;
	stroke: var(--sc-sage);
	fill: none;
}

.account__groups-intro p {
	font-family: var(--sc-font-ui);
	font-size: 0.88rem;
	color: var(--sc-text-secondary);
	line-height: 1.6;
	margin: 0;
	padding-top: 2px;
}

.settings-groups__actions {
	margin-bottom: 20px;
}

.groups-btn-create svg {
	width: 16px;
	height: 16px;
	margin-right: 2px;
}

/* Card grid */
.account__groups-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 14px;
}

.account__groups-empty {
	grid-column: 1 / -1;
	padding: 28px 24px;
	text-align: center;
	background: var(--sc-surface);
	border: 1px dashed var(--sc-border-subtle);
	border-radius: 16px;
}

.account__groups-empty p {
	font-family: var(--sc-font-ui);
	font-size: var(--sc-text-sm);
	color: var(--sc-text-secondary);
	margin: 0;
	line-height: 1.5;
}

.account__group-card {
	background: var(--sc-surface);
	border: 1px solid var(--sc-border-subtle);
	border-radius: 16px;
	padding: 24px;
	transition:
		border-color 0.2s,
		box-shadow 0.2s;
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.account__group-card:hover {
	border-color: var(--sc-sand);
	box-shadow: 0 4px 16px rgba(90, 64, 50, 0.05);
}

.account__group-card-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.account__group-card-name {
	font-family: var(--sc-font-ui);
	font-size: 0.95rem;
	font-weight: 600;
	color: var(--sc-bark);
	margin: 0;
}

.account__group-card-meta {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
}

.account__group-card-avatars {
	display: flex;
	align-items: center;
}

.account__group-card-count {
	font-family: var(--sc-font-ui);
	font-size: 0.78rem;
	color: var(--sc-text-tertiary);
}

.account__group-card-actions {
	display: flex;
	gap: 8px;
	margin-top: 4px;
	flex-wrap: wrap;
}

.account__group-card-actions .btn-sm svg {
	width: 14px;
	height: 14px;
}

/* Overlapping avatars on cards */
.settings-group-card__avatar {
	width: 30px;
	height: 30px;
	border-radius: 50%;
	border: 2px solid var(--sc-surface);
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--sc-font-ui);
	font-weight: 600;
	font-size: 0.68rem;
	color: white;
	margin-left: -6px;
}

.settings-group-card__avatar:first-child {
	margin-left: 0;
}

/* Create / edit modal — searchable member picker (chips + list) */
.groups-modal-form .groups-member-picker {
	margin-top: 8px;
}

.groups-member-chips {
	margin-bottom: 12px;
}

/* Mini-card style chips (extends .form-chip from forms.css) */
.groups-modal-form .groups-member-chip.form-chip {
	align-items: center;
	padding: 6px 8px 6px 6px;
	border-radius: 10px;
	gap: 8px;
	box-shadow: 0 1px 2px rgba(58, 53, 48, 0.06);
	max-width: 100%;
}

.groups-modal-form .groups-member-chip .form-chip__avatar {
	width: 26px;
	height: 26px;
	font-size: 0.55rem;
	flex-shrink: 0;
}

.groups-member-chip__name {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	max-width: 200px;
}

.groups-member-search {
	margin-bottom: 8px;
}

.groups-member-search__input {
	width: 100%;
}

.groups-member-pick-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
	max-height: 220px;
	overflow-y: auto;
	border: 1px solid var(--sc-border-subtle);
	border-radius: 10px;
	background: var(--sc-cream);
	padding: 6px;
}

.groups-member-pick-list > li {
	margin: 0;
}

.groups-member-pick-row {
	display: flex;
	align-items: center;
	gap: 10px;
	width: 100%;
	text-align: left;
	padding: 8px 10px;
	border: none;
	border-radius: 8px;
	background: var(--sc-surface);
	font-family: var(--sc-font-ui);
	font-size: 0.85rem;
	color: var(--sc-bark);
	cursor: pointer;
	transition:
		background 0.15s,
		box-shadow 0.15s;
}

.groups-member-pick-row:hover {
	background: var(--sc-cream-dark);
	box-shadow: 0 1px 0 rgba(58, 53, 48, 0.06);
}

.groups-member-pick-row:focus-visible {
	outline: none;
	box-shadow: var(--sc-focus-ring);
}

.groups-member-pick-row__avatar {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--sc-font-ui);
	font-weight: 600;
	font-size: 0.65rem;
	color: white;
	flex-shrink: 0;
}

.groups-member-pick-row__name {
	flex: 1;
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.groups-member-pick-row__add {
	font-size: 0.72rem;
	font-weight: 600;
	color: var(--sc-rust);
	flex-shrink: 0;
}

.groups-member-pick-empty {
	padding: 16px 12px;
	font-family: var(--sc-font-ui);
	font-size: 0.82rem;
	color: var(--sc-text-tertiary);
	text-align: center;
	line-height: 1.45;
	list-style: none;
}

.groups-modal-form .form-label {
	display: block;
	margin-bottom: 6px;
}

.groups-modal-form .settings-form__group + .settings-form__group {
	margin-top: var(--sc-space-lg);
}

.groups-modal__actions {
	margin-top: var(--sc-space-lg);
	padding-top: var(--sc-space-md);
}

.groups-delete-copy {
	font-family: var(--sc-font-body);
	font-size: var(--sc-text-base);
	color: var(--sc-text-primary);
	margin: 0 0 var(--sc-space-md);
	line-height: var(--sc-leading-relaxed);
}

.groups-delete-form .modal__actions {
	margin-top: 0;
	padding-top: 0;
	border-top: none;
}

@media (max-width: 768px) {
	.account__groups-grid {
		grid-template-columns: 1fr;
	}
}
