@import url('./tokens.css');

body.admin code {
    font-family: var(--font-admin-mono);
    background: var(--admin-surface-sunken);
    color: var(--admin-ink);
    padding: 1px 6px;
    border: 1px solid var(--admin-border);
    font-size: 0.95em;
}
body.admin p code { font-size: inherit; }

.cmd-broken {
    display: inline-block;
    margin-left: 6px;
    padding: 0 6px;
    font-family: var(--font-admin-mono);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    background: var(--admin-danger);
    color: var(--admin-surface-sunken);
}
.cmd-broken-row td { opacity: 0.65; }

.cmd-tips {
    margin: 8px 0 0;
    padding-left: 18px;
    color: var(--admin-ink-soft);
    font-size: 0.9em;
}
.cmd-tips li { margin-bottom: 4px; line-height: 1.5; }
.cmd-tips li:last-child { margin-bottom: 0; }
.cmd-tips strong { color: var(--admin-ink); font-weight: 700; }

body.admin {
    background: var(--admin-surface);
    color: var(--admin-ink);
    font-family: var(--font-body);
    font-size: var(--size-sm);
    line-height: 1.55;
    color-scheme: dark;
    font-feature-settings: "kern", "liga", "tnum";
}

.admin-nav {
    background: var(--admin-surface-sunken);
    border-bottom: 1px solid var(--admin-border);
    padding: var(--space-xs) var(--space-lg);
    display: flex;
    gap: var(--space-lg);
    align-items: center;
    font-family: var(--font-display);
    font-size: var(--size-sm);
    letter-spacing: 0.02em;
}
.admin-nav a {
    color: var(--admin-ink);
    text-decoration: none;
    padding-block: var(--space-2xs);
    transition: color var(--dur-fast) var(--ease-out);
}
.admin-nav a:hover { color: var(--admin-accent); }
.admin-nav a[aria-current="page"] {
    color: var(--admin-accent);
    border-bottom: 1px solid var(--admin-accent);
}
.admin-nav form { margin-left: auto; }

.admin-container {
    max-width: 1100px;
    margin-inline: auto;
    padding: var(--space-lg);
    display: flex;
    flex-direction: column;
    gap: var(--space-lg);
}

.panel {
    background: var(--admin-surface-raised);
    border: 1px solid var(--admin-border);
    padding: var(--space-md);
}
.panel > h2 {
    margin: 0 0 var(--space-sm);
    font-family: var(--font-display);
    font-size: var(--size-md);
    font-weight: 700;
    color: var(--admin-ink);
    letter-spacing: 0.01em;
}
.panel > h2 + p { margin-top: calc(var(--space-sm) * -0.5); color: var(--admin-ink-soft); }

.admin-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: end;
    gap: var(--space-md);
}

.admin-toolbar-hint {
    margin-top: var(--space-xs);
    color: var(--admin-ink-soft);
}

.admin-filter-form {
    display: flex;
    gap: var(--space-sm);
    align-items: center;
    flex-wrap: wrap;
}

.admin-filter-form input[type="text"] {
    min-width: 30ch;
    max-width: 40ch;
}

.admin-catalog-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--space-md);
}

.admin-catalog-card {
    display: block;
    padding: var(--space-md);
    background: var(--admin-surface-raised);
    border: 1px solid var(--admin-border);
    color: var(--admin-ink);
    text-decoration: none;
}

.admin-catalog-card:hover {
    border-color: var(--admin-accent);
    text-decoration: none;
}

.admin-catalog-card strong,
.admin-catalog-card span,
.admin-catalog-card small {
    display: block;
}

.admin-catalog-card span {
    margin-top: var(--space-xs);
    color: var(--admin-accent);
    font-family: var(--font-mono);
}

.admin-catalog-card small {
    margin-top: var(--space-xs);
    color: var(--admin-ink-soft);
    line-height: 1.5;
}

table.data {
    width: 100%;
    border-collapse: collapse;
    font-variant-numeric: tabular-nums;
    font-family: var(--font-mono);
    font-size: var(--size-sm);
}
table.data th {
    background: var(--admin-surface-sunken);
    color: var(--admin-ink-soft);
    text-align: left;
    font-family: var(--font-body);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: var(--size-xs);
    padding: var(--space-xs) var(--space-sm);
    border-bottom: 1px solid var(--admin-border);
}
table.data td {
    padding: var(--space-xs) var(--space-sm);
    border-bottom: 1px solid color-mix(in oklch, var(--admin-border) 50%, transparent);
}
table.data tr:hover td { background: color-mix(in oklch, var(--admin-accent) 8%, transparent); }
table.data tr:last-child td { border-bottom: 0; }

.btn {
    display: inline-block;
    background: var(--admin-accent);
    color: var(--admin-accent-ink);
    border: 1px solid var(--admin-accent);
    padding: var(--space-xs) var(--space-md);
    font-family: var(--font-display);
    font-size: var(--size-sm);
    font-weight: 700;
    letter-spacing: 0.02em;
    cursor: pointer;
    transition: background var(--dur-fast) var(--ease-out),
                color var(--dur-fast) var(--ease-out);
}
.btn:hover { background: transparent; color: var(--admin-accent); }

.btn-ghost {
    background: transparent;
    color: var(--admin-ink);
    border: 1px solid var(--admin-border);
}
.btn-ghost:hover { border-color: var(--admin-ink); color: var(--admin-ink); }

input[type="text"],
input[type="password"],
input[type="email"],
textarea,
select {
    background: var(--admin-surface-sunken);
    color: var(--admin-ink);
    border: 1px solid var(--admin-border);
    padding: var(--space-xs) var(--space-sm);
    font: inherit;
    width: 100%;
    max-width: 32ch;
    transition: border-color var(--dur-fast) var(--ease-out);
}
input:focus,
textarea:focus,
select:focus {
    outline: none;
    border-color: var(--admin-accent);
}

.log {
    background: var(--admin-surface-sunken);
    border: 1px solid var(--admin-border);
    padding: var(--space-sm) var(--space-md);
    font-family: var(--font-mono);
    font-size: var(--size-xs);
    line-height: 1.6;
    color: var(--admin-ink);
    white-space: pre-wrap;
    overflow-x: auto;
}

.error {
    color: var(--admin-danger);
    font-size: var(--size-sm);
    margin-top: var(--space-xs);
}

.stat-line {
    display: flex;
    align-items: baseline;
    gap: var(--space-sm);
    font-family: var(--font-mono);
    font-size: var(--size-sm);
    color: var(--admin-ink-soft);
}
.stat-line strong {
    color: var(--admin-ink);
    font-weight: 700;
    font-size: var(--size-lg);
    letter-spacing: -0.01em;
}
