[hidden] {
  display: none !important;
}

.keyku-main {
  gap: var(--space-5);
}

.keyku-stat-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-3);
}

.keyku-stat {
  min-block-size: 112px;
  display: grid;
  align-content: center;
  gap: var(--space-2);
}

.keyku-stat span,
.keyku-section-title span {
  color: var(--color-on-surface-muted);
  font-size: var(--type-label-medium-size);
  font-weight: 750;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.keyku-stat strong {
  color: var(--color-on-surface);
  font-size: var(--type-headline-large-size);
  line-height: var(--type-headline-large-line);
}

.keyku-vault-card {
  padding: var(--space-4);
}

.keyku-toolbar {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto minmax(180px, auto);
  gap: var(--space-3);
  align-items: center;
  margin-block-end: var(--space-4);
}

.keyku-search-field {
  min-width: 0;
}

.keyku-select {
  min-inline-size: 180px;
}

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

.keyku-key-row {
  min-block-size: 76px;
  display: grid;
  grid-template-columns: 52px minmax(0, 1fr) minmax(170px, 240px) 104px 120px;
  gap: var(--space-3);
  align-items: center;
  border: 1px solid var(--color-outline);
  border-radius: var(--radius-md);
  background: var(--color-surface-soft);
  padding: var(--space-3);
  transition: background var(--duration-fast) var(--ease-standard), transform var(--duration-fast) var(--ease-standard);
}

.keyku-key-row:hover,
.keyku-key-row:focus-visible {
  background: var(--color-surface-raised);
}

.keyku-key-row:active {
  transform: scale(0.995);
}

.keyku-key-row.is-muted {
  opacity: 0.72;
}

.keyku-row-number,
.keyku-secret-preview,
.keyku-mono,
.keyku-tech-row code {
  font-family: var(--font-mono);
}

.keyku-row-number {
  color: var(--color-on-surface-muted);
  font-weight: 800;
}

.keyku-row-main {
  min-width: 0;
}

.keyku-row-main strong {
  display: block;
  color: var(--color-on-surface);
  font-weight: 780;
  overflow-wrap: anywhere;
}

.keyku-row-main small,
.keyku-compact-row span,
.keyku-list-card small {
  display: block;
  color: var(--color-on-surface-muted);
  font-size: var(--type-label-medium-size);
  line-height: var(--type-label-medium-line);
}

.keyku-secret-preview {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--color-on-surface-muted);
  border: 1px solid var(--color-outline);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  padding: var(--space-2) var(--space-3);
}

.keyku-status {
  min-block-size: 36px;
  inline-size: fit-content;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  border: 1px solid var(--color-outline);
  border-radius: var(--radius-pill);
  padding-inline: var(--space-3);
  font-size: var(--type-label-medium-size);
  font-weight: 850;
  text-transform: uppercase;
}

.keyku-status::before {
  content: "";
  inline-size: 8px;
  block-size: 8px;
  border-radius: var(--radius-pill);
  background: currentColor;
}

.keyku-status.is-free {
  color: var(--color-success);
  background: var(--color-success-container);
}

.keyku-status.is-used {
  color: var(--color-on-surface-muted);
  background: var(--color-surface);
}

.keyku-row-actions {
  display: flex;
  justify-content: flex-end;
}

.keyku-row-button {
  inline-size: 100%;
}

.keyku-empty {
  min-block-size: 150px;
  display: grid;
  place-items: center;
  gap: var(--space-3);
  color: var(--color-on-surface-muted);
  border: 1px dashed var(--color-outline);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  text-align: center;
}

.keyku-empty strong {
  color: var(--color-on-surface);
}

.keyku-empty.is-compact {
  min-block-size: 76px;
  padding: var(--space-4);
}

.keyku-empty.is-error {
  color: var(--color-danger);
  border-color: var(--color-danger);
}

.keyku-ping-led {
  position: absolute;
  inset-block-start: 4px;
  inset-inline-end: 5px;
  inline-size: 10px;
  block-size: 10px;
  border-radius: var(--radius-pill);
  background: var(--color-danger);
  border: 2px solid var(--color-background);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-danger) 22%, transparent);
}

#notifications-button {
  position: relative;
}

.keyku-wide-sheet {
  inline-size: min(100%, 760px);
}

.keyku-sheet-body {
  display: grid;
  gap: var(--space-4);
  overflow: auto;
  max-block-size: min(720px, calc(100dvh - 150px));
  padding-block-start: var(--space-3);
}

.keyku-form-grid {
  display: grid;
  gap: var(--space-3);
}

.keyku-inline-field {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--space-2);
  align-items: center;
}

.keyku-inline-field .psu-button {
  white-space: nowrap;
}

.keyku-section-stack {
  display: grid;
  gap: var(--space-3);
}

.keyku-section-title {
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  color: var(--color-on-surface);
  font-size: var(--type-title-medium-size);
  line-height: var(--type-title-medium-line);
}

.keyku-list-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-3);
}

.keyku-identity-card {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.keyku-compact-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
  border: 1px solid var(--color-outline);
  border-radius: var(--radius-md);
  background: var(--color-surface-soft);
  padding: var(--space-3);
}

.keyku-tech-row {
  display: grid;
  grid-template-columns: 140px minmax(0, 1fr);
  gap: var(--space-3);
  align-items: start;
}

.keyku-tech-row span {
  color: var(--color-on-surface-muted);
  font-weight: 750;
}

.keyku-dialog-actions {
  justify-content: flex-end;
}

.keyku-toast {
  position: fixed;
  z-index: 90;
  inset-inline-start: 50%;
  inset-block-end: max(var(--space-4), env(safe-area-inset-bottom));
  transform: translate(-50%, var(--space-4));
  max-inline-size: min(520px, calc(100% - var(--space-8)));
  border: 1px solid var(--color-outline);
  border-radius: var(--radius-lg);
  background: var(--color-surface-raised);
  color: var(--color-on-surface);
  box-shadow: var(--shadow-floating);
  padding: var(--space-3) var(--space-4);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--duration-normal) var(--ease-standard), transform var(--duration-normal) var(--ease-standard);
}

.keyku-toast.is-visible {
  opacity: 1;
  transform: translate(-50%, 0);
}

.keyku-toast.is-success {
  border-color: var(--color-success);
}

.keyku-toast.is-error {
  border-color: var(--color-danger);
}

.keyku-share-card {
  inline-size: min(100%, 560px);
}

.keyku-share-key {
  margin-block: var(--space-5);
  overflow-wrap: anywhere;
  white-space: normal;
  font-size: var(--type-title-medium-size);
  line-height: var(--type-title-medium-line);
}

.keyku-clipboard-helper {
  position: fixed;
  inset-inline-start: -100vw;
  inset-block-start: 0;
}

code {
  font-family: var(--font-mono);
}

@media (max-width: 900px) {
  .keyku-toolbar {
    grid-template-columns: 1fr;
  }

  .keyku-select {
    inline-size: 100%;
  }

  .keyku-key-row {
    grid-template-columns: 44px minmax(0, 1fr) auto;
    grid-template-areas:
      "num main status"
      "secret secret secret"
      "actions actions actions";
  }

  .keyku-row-number { grid-area: num; }
  .keyku-row-main { grid-area: main; }
  .keyku-status { grid-area: status; }
  .keyku-secret-preview { grid-area: secret; }
  .keyku-row-actions { grid-area: actions; }
}

@media (max-width: 560px) {
  .keyku-stat-grid {
    grid-template-columns: 1fr;
  }

  .keyku-key-row {
    grid-template-columns: 1fr;
    grid-template-areas:
      "main"
      "status"
      "secret"
      "actions";
  }

  .keyku-row-number {
    display: none;
  }

  .keyku-row-actions,
  .keyku-row-actions .psu-button,
  .keyku-inline-field,
  .keyku-list-card,
  .keyku-tech-row,
  .keyku-compact-row {
    display: grid;
    grid-template-columns: 1fr;
  }

  .keyku-status {
    justify-self: start;
  }
}
