.admin-app { background: #f3f4f6; }
.admin-shell { display: grid; grid-template-columns: 11rem 1fr; min-height: 100vh; }
.admin-side { background: #2c2419; color: #f5ebe0; padding: 1rem 0.65rem; }
.admin-side a { display: block; padding: 0.45rem 0.6rem; color: #d4c4b0; text-decoration: none; border-radius: 6px; font-size: 0.86rem; }
.admin-side a:hover, .admin-side a.is-active { background: #b45309; color: #fff; }
.admin-body { padding: 1.25rem; }
.admin-side-title { padding: 0 0.6rem; font-weight: 700; margin: 0 0 0.6rem; font-size: 0.9rem; }
.admin-page-h1 { margin: 0 0 0.75rem; font-size: 1.3rem; }
.admin-card { background: #fff; border: 1px solid #e5e2dc; border-radius: 10px; padding: 1rem; margin-bottom: 1rem; }
.admin-card--wide { max-width: none; }
.admin-table { width: 100%; border-collapse: collapse; font-size: 0.88rem; }
.admin-table th, .admin-table td { padding: 0.4rem 0.5rem; border-bottom: 1px solid #eee; vertical-align: top; }
.admin-label { display: block; margin: 0.5rem 0 0.2rem; font-size: 0.84rem; font-weight: 600; }
.admin-input, .admin-textarea {
  width: 100%;
  max-width: 36rem;
  padding: 0.4rem 0.55rem;
  border: 1px solid #d0ccc4;
  border-radius: 6px;
  font: inherit;
}
.admin-input--narrow { max-width: 4rem; }
.admin-textarea { min-height: 2.5rem; resize: vertical; }
.admin-textarea--lao { font-family: "Noto Sans Lao", "Phetsarath OT", sans-serif; font-size: 1.05rem; }
.admin-btn {
  display: inline-block;
  padding: 0.45rem 0.85rem;
  border-radius: 6px;
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  font-size: 0.88rem;
  background: #fff;
}
.admin-btn--primary { background: #b45309; color: #fff; }
.admin-btn--ghost { border-color: #d0ccc4; color: inherit; }
.admin-flash--err { color: #a33; background: #fee; padding: 0.5rem; border-radius: 6px; }
.admin-flash--ok { color: #163; background: #efe; padding: 0.5rem; border-radius: 6px; }
.admin-toolbar { margin: 0 0 1rem; }
.admin-actions { white-space: nowrap; font-size: 0.82rem; }
.admin-actions a { margin-right: 0.35rem; }
.admin-inline-form { display: inline; }
.admin-link-btn { background: none; border: none; color: #a33; cursor: pointer; text-decoration: underline; font-size: inherit; padding: 0; }
.admin-table-scroll { overflow-x: auto; }
.admin-table--content { min-width: 64rem; font-size: 0.8rem; }
.admin-table--content .admin-textarea { max-width: none; min-width: 7rem; }
.admin-hint { font-size: 0.85rem; }
.admin-delete-list { list-style: none; padding: 0; margin: 0; max-height: 12rem; overflow-y: auto; font-size: 0.85rem; }
.admin-delete-list li { padding: 0.25rem 0; border-bottom: 1px solid #eee; }
.auth-panel { max-width: 22rem; margin: 3rem auto; padding: 1.5rem; background: #fff; border-radius: 10px; border: 1px solid #e5e2dc; }
@media (max-width: 768px) {
  .admin-shell { grid-template-columns: 1fr; }
  .admin-side { display: flex; flex-wrap: wrap; gap: 0.25rem; }
  .admin-side-title { width: 100%; }
}
