body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:#f7f7f5;color:#111;margin:0}
.shell{max-width:1100px;margin:0 auto;padding:28px 18px}
.card{background:#fff;border:1px solid #e9e9e5;border-radius:16px;padding:20px;box-shadow:0 8px 28px rgba(0,0,0,.04)}
.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.auth-card{width:min(420px,100%);background:#fff;border:1px solid #e9e9e5;border-radius:18px;padding:24px;box-shadow:0 18px 60px rgba(0,0,0,.06)}
.title{font-size:28px;font-weight:700;margin-bottom:6px}
.sub{font-size:13px;color:#666;margin-bottom:18px;line-height:1.6}
.grid{display:grid;gap:12px}
.row{display:grid;gap:8px}
label{font-size:12px;font-weight:600;color:#555}
input,select,textarea,button{font:inherit}
input,select,textarea{width:100%;padding:10px 12px;border-radius:10px;border:1px solid #ddd;background:#fff;box-sizing:border-box}
textarea{min-height:84px;resize:vertical}
button{height:40px;border:0;border-radius:10px;background:#111;color:#fff;font-weight:600;cursor:pointer}
button.alt{background:#f1f1ef;color:#111}
.actions{display:flex;gap:10px;flex-wrap:wrap}
.muted{color:#666;font-size:12px}
.link{color:#111;text-decoration:underline;text-underline-offset:2px}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}
.section{margin-top:18px}
.table{width:100%;border-collapse:collapse;font-size:13px}
.table th,.table td{padding:10px 8px;border-bottom:1px solid #eee;text-align:left;vertical-align:top}
.pill{display:inline-flex;align-items:center;height:24px;padding:0 10px;border-radius:999px;background:#f1f1ef;font-size:11px;font-weight:700}
.status-pending{background:#eff6ff;color:#1d4ed8}
.status-approved{background:#ecfdf5;color:#047857}
.status-rejected{background:#fef2f2;color:#b91c1c}
.two-col{display:grid;grid-template-columns:360px minmax(0,1fr);gap:18px}
@media (max-width:900px){.two-col{grid-template-columns:1fr}}
.flash{margin:12px 0;padding:10px 12px;border-radius:10px;background:#f1f5ff;color:#1d4ed8;font-size:12px;display:none}
.flash.error{background:#fef2f2;color:#b91c1c}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;word-break:break-all}
.nowrap{white-space:nowrap}
code{background:#f8f8f6;padding:2px 5px;border-radius:6px}
