/* Georgia Bison — shared design system.
   Tokens, primitives (buttons, nav, cards, modal), and the page utilities used
   by index.html, signup.html, account.html, admin.html, login.html. Page-
   specific styles live inline in each page's <style> block. */

/* ---------- Tokens ---------- */
:root{
  --ink:#141512;
  --ink-2:#3a3a35;
  --paper:#faf7f2;
  --paper-2:#f1ece2;
  --rule:#e3ddd0;
  --moss:#3d4a25;       /* deepened brand green */
  --moss-2:#586a36;
  --ember:#b3411f;      /* warm accent */
  --gold:#b8893d;
  --ok:#2f7a3b;
  --err:#a02525;
  --shadow:0 1px 2px rgba(20,21,18,.04), 0 8px 24px rgba(20,21,18,.06);
  --radius:14px;
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:"Karla","Inter",ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:"Fraunces","Playfair Display",Georgia,serif;font-weight:600;letter-spacing:-.01em;line-height:1.15;margin:0}
h1{font-size:clamp(2.4rem,5vw,4rem)}
h2{font-size:clamp(1.8rem,3.4vw,2.6rem)}
h3{font-size:1.25rem}
p{margin:0 0 1em}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
input,select,textarea{font:inherit}

.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.eyebrow{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--moss);font-weight:700}
.muted{color:var(--ink-2)}
.lead{font-size:1.15rem;color:var(--ink-2);max-width:60ch}
.center{text-align:center}
.max{max-width:760px;margin:0 auto}
.scroll-stop{scroll-margin-top:120px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:14px 22px;border-radius:999px;font-weight:700;
  transition:transform .08s ease, background .2s ease, color .2s ease, border-color .2s ease;
  border:1px solid transparent; white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn.primary{background:var(--ink);color:var(--paper)}
.btn.primary:hover:not(:disabled){background:var(--moss)}
.btn.ghost{border-color:var(--ink);color:var(--ink)}
.btn.ghost:hover:not(:disabled){background:var(--ink);color:var(--paper)}
.btn.ember{background:var(--ember);color:#fff}
.btn.ember:hover:not(:disabled){filter:brightness(1.05)}
.btn.sm{padding:10px 16px;font-size:.9rem}
.btn.lg{padding:18px 28px;font-size:1.05rem}
.btn.block{display:flex;width:100%;justify-content:center}

/* ---------- Top bar ---------- */
.promo{background:var(--ink);color:var(--paper);font-size:.85rem;text-align:center;padding:8px 16px;letter-spacing:.02em}
.promo strong{color:#f0c97a}

header.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(250,247,242,.92);backdrop-filter:saturate(1.2) blur(8px);
  border-bottom:1px solid var(--rule);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:24px}
.brand{display:flex;align-items:center;gap:10px;font-family:Fraunces,serif;font-weight:700;font-size:1.15rem;color:var(--ink)}
.brand-logo{
  /* The PNG has a white background; mix-blend-mode multiplies it into the
     ivory nav so the white square is invisible. Looks like a transparent
     PNG without actually being one. */
  width:44px;height:44px;object-fit:contain;mix-blend-mode:multiply;
}
.brand-mark{
  width:36px;height:36px;border-radius:50%;
  background:var(--ink);display:grid;place-items:center;color:var(--paper);
}
.navlinks{display:flex;gap:28px;align-items:center}
.navlinks a{font-weight:600;font-size:.95rem;color:var(--ink-2)}
.navlinks a:hover{color:var(--ink)}
.nav-cta{display:flex;gap:10px;align-items:center}
@media (max-width:820px){
  .navlinks{display:none}
}

/* ---------- Form primitives ---------- */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field label{font-size:.85rem;font-weight:700;color:var(--ink-2)}
.field .hint{font-size:.78rem;color:var(--ink-2);margin-top:2px}
.field input[type=text],
.field input[type=email],
.field input[type=tel],
.field input[type=password],
.field select,
.field textarea{
  padding:12px 14px;border-radius:10px;border:1px solid var(--rule);
  background:#fff;font-size:1rem;color:var(--ink);
  transition:border-color .15s, box-shadow .15s;
}
.field input:focus,
.field select:focus,
.field textarea:focus{
  outline:0;border-color:var(--moss);box-shadow:0 0 0 3px rgba(61,74,37,.12);
}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.row3{display:grid;grid-template-columns:2fr 1fr 1fr;gap:12px}
@media (max-width:600px){.row2,.row3{grid-template-columns:1fr}}

.notice{
  padding:14px 16px;border-radius:12px;font-size:.92rem;margin:0 0 14px;
  border:1px solid var(--rule);background:#fff;
}
.notice.err{border-color:#e3b3a8;background:#fbeae6;color:var(--err)}
.notice.ok{border-color:#bcd6b4;background:#eef6e9;color:var(--ok)}
.notice.info{border-color:var(--rule);background:var(--paper-2)}

/* ---------- Card ---------- */
.card{background:#fff;border:1px solid var(--rule);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}

/* ---------- Footer ---------- */
footer{background:var(--ink);color:#cfc7b4;padding:64px 0 32px;margin-top:80px}
.foot-grid{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:36px}
@media (max-width:820px){.foot-grid{grid-template-columns:1fr 1fr}}
footer h5{font-family:Karla,sans-serif;color:#fff;margin:0 0 14px;font-size:.85rem;letter-spacing:.14em;text-transform:uppercase}
footer a{display:block;color:#cfc7b4;padding:4px 0;font-size:.95rem}
footer a:hover{color:#fff}
.foot-bottom{margin-top:48px;padding-top:24px;border-top:1px solid #2a2925;color:#8e887a;font-size:.85rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px}

/* ---------- Modal ---------- */
.modal-bg{position:fixed;inset:0;background:rgba(20,21,18,.55);display:none;align-items:center;justify-content:center;z-index:100;padding:24px}
.modal-bg.show{display:flex}
.modal{background:var(--paper);border-radius:20px;padding:32px;max-width:520px;width:100%;box-shadow:0 30px 80px rgba(0,0,0,.3)}
.modal h3{font-size:1.5rem;margin-bottom:8px}
.modal .row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px dashed var(--rule);font-size:.95rem}
.modal .row.total{font-weight:700;border-bottom:0;border-top:1px solid var(--rule);padding-top:12px;font-size:1.05rem}
.modal .actions{display:flex;gap:10px;margin-top:20px;justify-content:flex-end}

/* ---------- Toast ---------- */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%);
  background:var(--ink);color:#fff;padding:12px 20px;border-radius:999px;
  font-size:.9rem;z-index:200;box-shadow:0 8px 24px rgba(0,0,0,.2);
  opacity:0;transition:opacity .3s;pointer-events:none;
}
.toast.show{opacity:1}

/* ---------- Staff backend layout ---------- */
.staff-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh;background:var(--paper-2)}
@media (max-width:820px){.staff-shell{grid-template-columns:1fr}}
.staff-side{
  background:var(--ink);color:#cfc7b4;padding:24px 16px;
  position:sticky;top:0;height:100vh;overflow-y:auto;
}
@media (max-width:820px){.staff-side{position:static;height:auto}}
.staff-side .brand{color:#fff;margin-bottom:24px}
.staff-side nav{display:flex;flex-direction:column;gap:2px}
.staff-side nav a{
  color:#cfc7b4;padding:10px 12px;border-radius:8px;font-size:.95rem;font-weight:600;
}
.staff-side nav a:hover{background:rgba(255,255,255,.06);color:#fff}
.staff-side nav a.active{background:rgba(255,255,255,.1);color:#fff}
.staff-side .who{margin-top:auto;padding:12px;border-top:1px solid #2a2925;font-size:.85rem;color:#a8a18a}
.staff-side .who strong{color:#fff;display:block}
.staff-side .role-pill{
  display:inline-block;padding:2px 8px;border-radius:999px;font-size:.7rem;font-weight:700;
  background:rgba(255,255,255,.1);color:#fff;letter-spacing:.04em;text-transform:uppercase;
}
.staff-main{padding:32px 36px}
@media (max-width:820px){.staff-main{padding:24px 20px}}
.staff-head{display:flex;justify-content:space-between;align-items:end;flex-wrap:wrap;gap:16px;margin-bottom:24px}
.staff-head h1{font-size:clamp(1.6rem,2.6vw,2rem)}

.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
@media (max-width:900px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}
.kpi{background:#fff;border:1px solid var(--rule);border-radius:12px;padding:16px}
.kpi .label{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2)}
.kpi .num{font-family:Fraunces,serif;font-size:1.8rem;line-height:1;margin-top:4px}
.kpi .sub{font-size:.82rem;color:var(--ink-2);margin-top:4px}

.staff-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--rule);border-radius:12px;overflow:hidden}
.staff-table th{
  text-align:left;padding:12px;background:var(--paper-2);border-bottom:1px solid var(--rule);
  font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2);
}
.staff-table td{padding:12px;border-bottom:1px solid var(--rule);vertical-align:middle;font-size:.92rem}
.staff-table tr:last-child td{border-bottom:0}
.staff-table tr.low{background:#fbeae6}
.staff-table .num-input{
  width:80px;padding:6px 8px;border:1px solid var(--rule);border-radius:6px;text-align:right;font:inherit;
}
.staff-table .num-input:focus{outline:0;border-color:var(--moss);box-shadow:0 0 0 3px rgba(61,74,37,.15)}

.role-badge{display:inline-block;padding:3px 9px;border-radius:999px;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.role-badge.admin   { background:#e0d5b5; color:#5a4818 }
.role-badge.manager { background:#d0e0d0; color:#2f5a3b }
.role-badge.packer  { background:#d8e0eb; color:#28456e }
