@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600&family=IBM+Plex+Mono:wght@400;500&family=IBM+Plex+Sans:wght@400;500;600;700&display=swap');

:root{
  --bg:#f4f1ec;
  --ink:#1c1813;
  --ink-soft:#3b342b;
  --paper:#ffffff;
  --line:#e4ddd0;
  --line-soft:#efe9dd;
  --muted:#8a8070;
  --accent:#c8761a;
  --accent-dark:#a35f10;
  --danger:#b3392f;
  --shadow:0 1px 2px rgba(28,24,19,.05),0 12px 30px -18px rgba(28,24,19,.35);
  --radius:13px;
  --mono:'IBM Plex Mono',ui-monospace,monospace;
  --sans:'IBM Plex Sans',system-ui,sans-serif;
  --display:'Fraunces',Georgia,serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--bg);
  background-image:radial-gradient(circle at 1px 1px,rgba(28,24,19,.035) 1px,transparent 0);
  background-size:22px 22px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--accent-dark);text-decoration:none}
a:hover{text-decoration:underline}

/* ---------- Public (centered card) pages ---------- */
.public-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px 18px}
.card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:34px;
  width:100%;
  max-width:520px;
}
.card-title{font-family:var(--display);font-weight:600;font-size:27px;margin:0 0 18px}

/* ---------- Forms ---------- */
.stack{display:flex;flex-direction:column;gap:15px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:600;color:var(--ink-soft)}
input,select{
  font-family:var(--sans);font-size:15px;color:var(--ink);
  background:#fffdfa;border:1px solid var(--line);border-radius:9px;
  padding:11px 12px;width:100%;transition:border-color .15s,box-shadow .15s;
}
input:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(200,118,26,.16)}
select{cursor:pointer}

.btn{
  display:inline-block;font-family:var(--sans);font-weight:700;font-size:15px;
  background:var(--accent);color:#fff;border:none;border-radius:9px;
  padding:12px 20px;cursor:pointer;transition:background .15s,transform .05s;text-align:center;
}
.btn:hover{background:var(--accent-dark);text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn-sm{padding:7px 12px;font-size:13px;border-radius:8px}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn-ghost:hover{background:#faf7f1;color:var(--ink)}
.btn-danger{background:transparent;color:var(--danger);border:1px solid #e7c9c5}
.btn-danger:hover{background:#fbeeed;color:var(--danger)}

/* ---------- Alerts ---------- */
.alert{padding:12px 14px;border-radius:10px;font-size:14px;margin-bottom:14px;border:1px solid}
.alert-success{background:#eef6ec;border-color:#cfe6c8;color:#2f6d28}
.alert-error{background:#fbeeed;border-color:#ecc9c5;color:#9b332a}
.alert-info{background:#eef2f7;border-color:#cdd8e6;color:#34597f}
.muted{color:var(--muted)}
.mono{font-family:var(--mono);font-size:13px}
.breakable{word-break:break-all}
.install-log{font-size:14px;color:var(--ink-soft);padding-left:18px}
.install-log li{margin:4px 0}
code{font-family:var(--mono);background:#f0ebe1;padding:1px 6px;border-radius:5px;font-size:13px}

/* ---------- Admin shell ---------- */
.admin-page{min-height:100vh;display:flex;flex-direction:column}
.topbar{
  display:flex;align-items:center;gap:22px;flex-wrap:wrap;
  background:var(--ink);color:#f4f1ec;padding:0 24px;height:60px;
}
.brand{font-family:var(--display);font-weight:600;font-size:19px}
.brand-tag{font-family:var(--mono);font-size:11px;color:var(--accent);
  border:1px solid rgba(200,118,26,.5);border-radius:5px;padding:1px 6px;margin-left:2px}
.mainnav{display:flex;gap:4px;margin-left:8px}
.mainnav a{color:#cdc6ba;padding:8px 13px;border-radius:8px;font-size:14px;font-weight:600}
.mainnav a:hover{color:#fff;background:rgba(255,255,255,.07);text-decoration:none}
.mainnav a.active{color:var(--ink);background:var(--accent)}
.userbox{margin-left:auto;display:flex;align-items:center;gap:12px}
.userbox .who{font-size:13px;color:#cdc6ba;font-family:var(--mono)}
.userbox .btn-ghost{color:#f4f1ec;border-color:rgba(255,255,255,.25)}
.userbox .btn-ghost:hover{background:rgba(255,255,255,.1);color:#fff}

.content{flex:1;width:100%;max-width:1080px;margin:0 auto;padding:30px 24px 60px}
.page-title{font-family:var(--display);font-weight:600;font-size:30px;margin:4px 0 22px}
.footer{text-align:center;color:var(--muted);font-size:12px;padding:18px;border-top:1px solid var(--line)}

/* ---------- Panels & layout ---------- */
.panel{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:22px;margin-bottom:22px}
.panel-title{font-size:15px;font-weight:700;margin:0 0 14px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:22px}
@media(max-width:760px){.grid2{grid-template-columns:1fr}.row2{grid-template-columns:1fr}}

.statgrid{display:flex;flex-wrap:wrap;gap:12px}
.stat{display:flex;flex-direction:column;gap:8px;align-items:flex-start;
  background:#faf8f4;border:1px solid var(--line-soft);border-radius:11px;padding:14px 16px;min-width:104px}
.stat:hover{text-decoration:none;border-color:var(--accent);transform:translateY(-1px);transition:.12s}
.stat-num{font-family:var(--display);font-size:30px;font-weight:600;color:var(--ink);line-height:1}

/* ---------- Tables ---------- */
.table{width:100%;border-collapse:collapse;background:var(--paper);
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;font-size:14px}
.table thead th{background:#faf8f4;text-align:left;padding:11px 14px;font-size:12px;
  text-transform:uppercase;letter-spacing:.05em;color:var(--muted);border-bottom:1px solid var(--line)}
.table td{padding:11px 14px;border-bottom:1px solid var(--line-soft);vertical-align:middle}
.table tr:last-child td{border-bottom:none}
.table tbody tr:hover{background:#fcfaf6}
.actions-col{width:1%;white-space:nowrap}
.actions{display:flex;gap:7px;align-items:center;flex-wrap:wrap}
.inline{display:inline}
select.mini{padding:6px 8px;font-size:13px;border-radius:7px;width:auto}

/* ---------- Toolbar / filters ---------- */
.toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;gap:12px;flex-wrap:wrap}
.filters{display:flex;gap:7px;flex-wrap:wrap}
.chip{font-size:13px;padding:6px 13px;border-radius:999px;border:1px solid var(--line);
  background:var(--paper);color:var(--ink-soft);font-weight:600;text-transform:capitalize}
.chip:hover{text-decoration:none;border-color:var(--accent)}
.chip.on{background:var(--ink);color:#f4f1ec;border-color:var(--ink)}

.inline-form{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.inline-form input{width:auto;flex:1;min-width:150px}

/* ---------- Status pills ---------- */
.pill{display:inline-block;font-family:var(--mono);font-size:11px;font-weight:500;
  padding:3px 9px;border-radius:999px;text-transform:uppercase;letter-spacing:.04em;border:1px solid}
.pill-registered{background:#eef2f7;color:#3f618a;border-color:#cdd8e6}
.pill-confirmed{background:#e9f3f1;color:#2c7368;border-color:#c5e2db}
.pill-approved{background:#fdf1e3;color:#a35f10;border-color:#f0d6b3}
.pill-cancelled{background:#f1eeea;color:#766a5b;border-color:#ddd5c8}
.pill-available{background:#eef6ec;color:#3a7a30;border-color:#cfe6c8}
.pill-taken{background:#fdf1e3;color:#a35f10;border-color:#f0d6b3}
.pill-removed{background:#fbeeed;color:#9b332a;border-color:#ecc9c5}
