/* The Kettle Black — Admin brand kit */
:root{
  --ink:#1A1A1A; --ink-soft:#3f3a34; --paper:#ffffff;
  --cream:#F6F7F2; --cream-2:#EEEDE6; --cream-3:#E2DDD4;
  --stone:#808080; --stone-soft:#6b655e; --line:#E2DDD4;
  --plum:#6B2D5C; --plum-deep:#4A1E40; --plum-tint:#F0E4EC;
  --good:#2f7d52; --good-bg:#E3F0E8; --warn:#9c6a16; --warn-bg:#F6ECD6; --bad:#b23a3a; --bad-bg:#F6E0E0;
  --disp:'Cormorant Garamond',Georgia,serif; --body:'Open Sans',system-ui,sans-serif;
  --shadow:0 18px 44px rgba(26,26,26,.10); --shadow-sm:0 6px 18px rgba(26,26,26,.06);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--body);background:var(--cream);color:var(--ink);line-height:1.55;-webkit-font-smoothing:antialiased}
.serif{font-family:var(--disp)}
a{color:var(--plum);text-decoration:none}
h1,h2,h3{font-family:var(--disp);font-weight:600;line-height:1.1}
.muted{color:var(--stone-soft)}
.small{font-size:12.5px}
button,input,select,textarea{font-family:inherit}
input,select,textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:10px;font-size:14px;background:#fff;color:var(--ink)}
input:focus,select,textarea:focus{outline:none;border-color:var(--plum)}
label{display:block;font-size:12px;font-weight:600;color:var(--ink-soft);margin:0 0 5px;letter-spacing:.01em}
.field{margin-bottom:14px}
.row{display:grid;gap:12px}
.row.c2{grid-template-columns:1fr 1fr}.row.c3{grid-template-columns:1fr 1fr 1fr}
@media(max-width:640px){.row.c2,.row.c3{grid-template-columns:1fr}}
.btn{display:inline-flex;align-items:center;gap:7px;padding:11px 18px;border:1px solid var(--plum);border-radius:24px;background:var(--plum);color:#fff;font-weight:600;font-size:14px;cursor:pointer;transition:.15s}
.btn:hover{background:var(--plum-deep);border-color:var(--plum-deep)}
.btn.ghost{background:#fff;color:var(--plum)}.btn.ghost:hover{background:var(--plum-tint)}
.btn.sm{padding:7px 13px;font-size:12.5px}
.btn.dark{background:var(--ink);border-color:var(--ink)}.btn.dark:hover{background:#000}
.chip{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:11.5px;font-weight:600;background:var(--cream-2);color:var(--ink-soft)}
.chip.good{background:var(--good-bg);color:var(--good)}.chip.warn{background:var(--warn-bg);color:var(--warn)}.chip.bad{background:var(--bad-bg);color:var(--bad)}
.card{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:var(--shadow-sm)}
table{width:100%;border-collapse:collapse;font-size:13.5px}
th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--stone-soft);font-weight:700;padding:9px 10px;border-bottom:2px solid var(--cream-3)}
td{padding:10px;border-bottom:1px solid var(--cream-2);vertical-align:top}
tr:hover td{background:var(--cream)}
.num{text-align:right;font-variant-numeric:tabular-nums}
/* pipeline kanban — desktop = all columns, mobile = swipeable full-width columns that stay within the screen */
.board{display:grid;grid-template-columns:repeat(var(--ncol),minmax(180px,1fr));gap:12px;align-items:start;overflow-x:auto}
@media(max-width:760px){.board{grid-template-columns:none;grid-auto-flow:column;grid-auto-columns:86%;scroll-snap-type:x proximity;padding-bottom:8px}.board>*{scroll-snap-align:start}}
.kpi{background:#fff;border:1px solid var(--line);border-radius:12px;padding:13px 15px}
.kpi .v{font-family:var(--body);font-size:21px;font-weight:700;line-height:1.1;letter-spacing:-.015em;font-variant-numeric:tabular-nums;color:var(--ink,#1a1018)}
.kpi .l{font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--stone-soft);margin-top:5px;font-weight:600}
.empty{text-align:center;color:var(--stone-soft);padding:40px 20px;font-size:14px}
