/* Admin panel — quiet, functional, same palette as the public site */
.admin-body {
    background: var(--paper-alt, #F1EDE2);
    font-family: 'Inter', system-ui, sans-serif;
    margin: 0;
    color: var(--ink, #1C2321);
}
.login-box {
    max-width: 360px;
    margin: 90px auto;
    background: #fff;
    border: 1px solid var(--line, #D8D3C4);
    border-radius: 10px;
    padding: 32px;
}
.login-box h1 { font-size: 1.3rem; margin-bottom: 18px; }
.login-box label { display: block; font-size: .85rem; font-weight: 600; margin-bottom: 12px; }
.login-box input {
    width: 100%; padding: 9px 10px; margin-top: 4px;
    border: 1px solid var(--line, #D8D3C4); border-radius: 6px; font-size: .95rem;
}
.login-box button {
    width: 100%; background: var(--green, #226B4E); color: #fff; border: none;
    padding: 11px; border-radius: 8px; font-weight: 700; cursor: pointer; margin-top: 6px;
}
.admin-error { background: #fbe4e4; color: #a12727; padding: 8px 12px; border-radius: 6px; font-size: .85rem; }

.admin-shell { display: flex; min-height: 100vh; }
.admin-sidebar {
    width: 210px; background: var(--ink, #1C2321); color: #cfd6cf; flex-shrink: 0;
    padding: 22px 16px; display: flex; flex-direction: column;
}
.admin-sidebar h2 { color: #fff; font-size: 1.1rem; margin-bottom: 24px; }
.admin-sidebar a { display: block; color: #cfd6cf; padding: 9px 10px; border-radius: 6px; font-size: .92rem; margin-bottom: 2px; }
.admin-sidebar a:hover, .admin-sidebar a.active { background: rgba(255,255,255,.08); color: #fff; }
.admin-sidebar .logout { margin-top: auto; color: #e8a33d; }

.admin-main { flex: 1; padding: 28px 34px; max-width: 1100px; }
.admin-main h1 { font-size: 1.5rem; margin-bottom: 4px; }
.admin-sub { color: #52584f; margin-bottom: 24px; font-size: .92rem; }

.stat-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 14px; margin-bottom: 30px; }
.stat-card { background: #fff; border: 1px solid var(--line, #D8D3C4); border-radius: 10px; padding: 16px 18px; }
.stat-card .num { font-family: 'Space Grotesk', sans-serif; font-size: 1.7rem; font-weight: 700; }
.stat-card .label { font-size: .8rem; color: #52584f; text-transform: uppercase; letter-spacing: .04em; }

.admin-panel { background: #fff; border: 1px solid var(--line, #D8D3C4); border-radius: 10px; padding: 20px; margin-bottom: 26px; }
.admin-panel h3 { font-size: 1.05rem; margin-bottom: 14px; }

table.admin-table { width: 100%; border-collapse: collapse; font-size: .9rem; }
table.admin-table th, table.admin-table td { text-align: left; padding: 9px 10px; border-bottom: 1px solid var(--line, #D8D3C4); }
table.admin-table th { font-size: .76rem; text-transform: uppercase; letter-spacing: .04em; color: #52584f; }
.tag { font-size: .72rem; font-weight: 700; padding: 2px 8px; border-radius: 20px; }
.tag-active { background: #dff0e6; color: #164B36; }
.tag-expired { background: #f1e3c9; color: #8a5c15; }
.tag-disabled { background: #f1e0e0; color: #a12727; }

.admin-form label { display: block; font-weight: 600; font-size: .85rem; margin: 14px 0 4px; }
.admin-form input, .admin-form textarea, .admin-form select {
    width: 100%; padding: 9px 10px; border: 1px solid var(--line, #D8D3C4); border-radius: 6px; font-size: .92rem; font-family: inherit;
}
.admin-form textarea { min-height: 90px; }
.btn-primary { background: var(--green, #226B4E); color: #fff; border: none; padding: 10px 18px; border-radius: 8px; font-weight: 700; cursor: pointer; margin-top: 16px; }
.btn-danger { background: #a12727; color: #fff; border: none; padding: 6px 12px; border-radius: 6px; font-size: .8rem; cursor: pointer; }
.btn-small { padding: 5px 10px; font-size: .8rem; border-radius: 6px; border: 1px solid var(--line, #D8D3C4); background: #fff; cursor: pointer; }
.actions-cell { display: flex; gap: 6px; }
.top-link { display: inline-block; margin-bottom: 16px; font-size: .88rem; }
