/* Account index/detail UI */

@layer components {
  .account-projects-index {
    display: grid;
    gap: var(--space-6);
  }

  .account-projects-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-4);
  }

  .project-list-item--blocked {
    border-color: var(--color-warning-border);
    background: color-mix(in oklch, var(--color-warning-canvas) 28%, transparent);
  }

  .account-summary-strip {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-3);
    margin-block-end: var(--space-6);
  }

  .account-summary-strip > div {
    padding: var(--space-4);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
  }

  .account-summary-strip span {
    display: block;
    color: var(--color-ink-muted);
    font-size: var(--text-xs);
    font-weight: var(--font-semibold);
    letter-spacing: 0.08em;
    text-transform: uppercase;
  }

  .account-summary-strip strong {
    display: block;
    margin-block-start: var(--space-1);
    font-size: var(--text-xl);
  }

  .account-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(18rem, 1fr));
    gap: var(--space-4);
  }

  .account-list {
    display: grid;
    gap: var(--space-2);
  }

  .account-list-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    padding: var(--space-4);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
  }

  .account-list-row--attention {
    border-color: var(--color-warning-border);
    background: color-mix(in oklch, var(--color-warning-canvas) 24%, var(--color-surface));
  }

  .account-list-main {
    display: grid;
    gap: var(--space-1);
    min-inline-size: 0;
    color: var(--color-ink);
    text-decoration: none;
  }

  .account-list-main:hover .account-list-name {
    color: var(--color-primary);
  }

  .account-list-name {
    font-size: var(--text-xl);
    font-weight: var(--font-semibold);
    transition: color var(--duration-fast) var(--ease-out);
  }

  .account-list-meta {
    color: var(--color-ink-muted);
    font-size: var(--text-sm);
  }

  .account-list-status {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: var(--space-2);
    flex: 0 0 auto;
  }

  .account-card--attention {
    border-color: var(--color-warning-border);
    background: color-mix(in oklch, var(--color-warning-canvas) 35%, var(--color-surface));
  }

  .account-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-3);
    margin-block-end: var(--space-4);
  }

  .account-card-header h2 {
    margin: 0;
    font-size: var(--text-xl);
  }

  .account-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-3);
    margin: 0 0 var(--space-4);
  }

  .account-stats--wide {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .account-stats div {
    padding: var(--space-3);
    background: var(--color-surface-muted);
    border: 1px solid var(--color-border-muted);
    border-radius: var(--radius-md);
  }

  .account-stats dt {
    color: var(--color-ink-muted);
    font-size: var(--text-xs);
    font-weight: var(--font-semibold);
    letter-spacing: 0.08em;
    text-transform: uppercase;
  }

  .account-stats dd {
    margin: var(--space-1) 0 0;
    color: var(--color-ink);
    font-size: var(--text-lg);
    font-weight: var(--font-semibold);
  }

  .account-project-list {
    display: grid;
    gap: var(--space-2);
    margin: 0;
    padding: 0;
    list-style: none;
  }

  .account-project-list li,
  .account-project-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    padding: var(--space-3);
    border: 1px solid var(--color-border-muted);
    border-radius: var(--radius-md);
  }

  .account-project-list span {
    color: var(--color-ink-muted);
    font-size: var(--text-sm);
  }

  .account-detail-grid {
    display: grid;
    grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
    gap: var(--space-6);
  }

  .account-detail-grid--balanced {
    grid-template-columns: minmax(18rem, 0.85fr) minmax(0, 1.15fr);
  }

  .account-projects {
    display: grid;
    gap: var(--space-3);
  }

  .account-project-row--link {
    color: var(--color-ink);
    text-decoration: none;
  }

  .account-project-row--link:hover {
    border-color: var(--color-border-accent);
    text-decoration: none;
  }

  .project-transfer-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-6);
  }

  .project-transfer-grid h3 {
    margin-block-start: 0;
  }

  .account-transfer-form {
    display: flex;
    align-items: center;
    gap: var(--space-2);
  }

  .account-transfer-form--stacked {
    align-items: stretch;
    flex-direction: column;
  }

  .account-transfer-form .form-select {
    min-inline-size: 12rem;
  }

  .pending-transfer-list {
    display: grid;
    gap: var(--space-2);
    color: var(--color-ink-muted);
    font-size: var(--text-sm);
  }

  .pending-transfer-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-2);
    padding: var(--space-2);
    border: 1px solid var(--color-border-muted);
    border-radius: var(--radius-md);
  }

  .account-page-hero {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-6);
    margin-block-end: var(--space-6);
  }

  .account-page-hero h1 {
    margin: 0;
  }

  .account-meta-line {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-2);
    margin-block-start: var(--space-2);
    color: var(--color-ink-muted);
  }

  .account-meta-line span:not(:last-child)::after {
    content: "·";
    margin-inline-start: var(--space-2);
    color: var(--color-ink-faint);
  }

  .account-hero-actions {
    position: relative;
    display: flex;
    align-items: center;
    gap: var(--space-2);
  }

  .account-actions-menu {
    position: relative;
  }

  .account-actions-menu summary {
    list-style: none;
  }

  .account-actions-menu summary::-webkit-details-marker {
    display: none;
  }

  .account-actions-popover {
    position: absolute;
    z-index: 20;
    inset-block-start: calc(100% + var(--space-2));
    inset-inline-end: 0;
    display: grid;
    gap: var(--space-2);
    inline-size: 13rem;
    padding: var(--space-2);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
  }

  .account-actions-popover form {
    margin: 0;
  }

  .account-menu-link {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    inline-size: 100%;
    padding: var(--space-2) var(--space-3);
    color: var(--color-ink);
    background: transparent;
    border: 1px solid transparent;
    border-radius: var(--radius-md);
    font: inherit;
    font-weight: var(--font-semibold);
    text-align: start;
    text-decoration: none;
    cursor: pointer;
  }

  .account-menu-link:hover {
    background: var(--color-surface-muted);
    border-color: var(--color-border-muted);
    text-decoration: none;
  }

  .account-menu-link--danger {
    color: var(--color-negative);
  }

  .account-menu-link:disabled {
    color: var(--color-ink-faint);
    cursor: not-allowed;
    opacity: 0.7;
  }

  .account-recovery-panel {
    display: grid;
    gap: var(--space-5);
    margin-block-end: var(--space-6);
    padding: var(--space-6);
    background:
      radial-gradient(circle at top right, color-mix(in oklch, var(--color-primary) 16%, transparent), transparent 34%),
      var(--color-surface);
    border: 1px solid var(--color-border-accent);
    border-radius: var(--radius-xl);
  }

  .account-recovery-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-4);
  }

  .account-recovery-head h2 {
    margin: var(--space-1) 0;
    font-size: var(--text-2xl);
  }

  .account-recovery-head p {
    margin: 0;
    color: var(--color-ink-muted);
  }

  .account-plan-options {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-4);
  }

  .account-plan-option {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    min-block-size: 22rem;
    padding: var(--space-5);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
  }

  .account-plan-option--featured {
    border-color: var(--color-border-accent);
    background:
      radial-gradient(circle at top, color-mix(in oklch, var(--color-primary) 10%, transparent), transparent 46%),
      var(--color-surface);
  }

  .account-plan-option-head {
    min-block-size: 4.5rem;
  }

  .account-plan-option-head h3 {
    margin: 0;
    font-size: var(--text-xl);
  }

  .account-plan-option-head p,
  .account-plan-price {
    margin: 0;
  }

  .account-plan-option-head p {
    color: var(--color-ink-muted);
    font-size: var(--text-sm);
  }

  .account-plan-price span {
    color: var(--color-ink);
    font-size: var(--text-3xl);
    font-weight: var(--font-bold);
    letter-spacing: -0.04em;
  }

  .account-plan-price small {
    color: var(--color-ink-muted);
    font-size: var(--text-sm);
  }

  .account-plan-note {
    display: grid;
    gap: var(--space-1);
    min-block-size: 4.75rem;
    margin: 0;
    color: var(--color-ink-muted);
    font-size: var(--text-sm);
  }

  .account-plan-note--warning {
    min-block-size: auto;
    padding: var(--space-3);
    background: color-mix(in oklch, var(--color-warning-canvas) 38%, transparent);
    border: 1px solid var(--color-warning-border);
    border-radius: var(--radius-md);
  }

  .account-plan-note strong {
    color: var(--color-warning);
  }

  .account-plan-note span {
    color: var(--color-ink-muted);
  }

  .account-plan-option form {
    margin-block-start: auto;
  }

  .account-plan-cta {
    min-block-size: 3rem;
  }

  .account-pricing-footnote {
    margin: 0;
    color: var(--color-ink-muted);
    font-size: var(--text-sm);
    text-align: center;
  }

  .account-dashboard-stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-3);
    margin-block-end: var(--space-6);
  }

  .account-dashboard-stats > div {
    padding: var(--space-4);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
  }

  .account-dashboard-stats span {
    display: block;
    color: var(--color-ink-muted);
    font-size: var(--text-xs);
    font-weight: var(--font-semibold);
    letter-spacing: 0.08em;
    text-transform: uppercase;
  }

  .account-dashboard-stats strong {
    display: block;
    margin-block-start: var(--space-1);
    font-size: var(--text-2xl);
    letter-spacing: -0.04em;
  }

  .account-dashboard-grid,
  .account-settings-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(18rem, 0.75fr);
    gap: var(--space-6);
  }

  .project-list--compact {
    gap: var(--space-2);
  }

  .account-settings-card h2 {
    margin: 0;
    font-size: var(--text-lg);
  }

  .account-summary-list {
    display: grid;
    gap: var(--space-3);
  }

  .account-summary-list > div {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    padding-block-end: var(--space-2);
    border-block-end: 1px solid var(--color-border-muted);
  }

  .account-summary-list span {
    color: var(--color-ink-muted);
    font-size: var(--text-sm);
  }

  .account-summary-list strong {
    color: var(--color-ink);
  }

  .account-member-list {
    display: grid;
    gap: var(--space-2);
  }

  .account-member-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    padding: var(--space-3);
    border: 1px solid var(--color-border-muted);
    border-radius: var(--radius-md);
  }

  .account-member-row p {
    margin: 0;
  }

  @media (max-width: 900px) {
    .account-detail-grid,
    .account-summary-strip,
    .account-stats,
    .account-stats--wide,
    .account-plan-options,
    .account-dashboard-stats,
    .account-dashboard-grid,
    .account-settings-grid {
      grid-template-columns: 1fr;
    }

    .account-page-hero,
    .account-list-row,
    .account-recovery-head,
    .account-member-row,
    .project-transfer-grid,
    .account-project-row,
    .account-transfer-form {
      align-items: stretch;
      flex-direction: column;
    }

    .account-hero-actions,
    .account-list-status {
      justify-content: flex-start;
    }

    .account-actions-popover {
      inset-inline: auto 0;
    }
  }
}
