/* Smoky Mountain Grocery — Manager dashboard. B&W, matches the site/email look. */
:root{
  --ink:#1a1a1a; --mute:#5e5e5e; --line:#dcdcdc; --soft:#f5f5f3; --bg:#ececea;
  --ok:#1f7a3d; --warn:#9a6a00; --bad:#9a2020; --accent:#1a1a1a;
  --sans:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --serif:Georgia,'Times New Roman',serif;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:15px;line-height:1.45}
h1,h2{font-family:var(--serif);font-weight:800;margin:0 0 6px}
h2{font-size:18px}
.muted{color:var(--mute)}
button{font-family:var(--sans);cursor:pointer;border-radius:8px;border:1px solid var(--ink);background:var(--ink);color:#fff;padding:10px 16px;font-weight:700;font-size:14px}
button:hover{opacity:.9}
button.ghost{background:#fff;color:var(--ink);border-color:#bbb;font-weight:600}
button.ghost:hover{background:var(--soft)}
input,select,textarea{font-family:var(--sans);font-size:15px;padding:10px 12px;border:1px solid #c4c4c4;border-radius:8px;background:#fff;color:var(--ink);width:100%}
input:focus,select:focus,textarea:focus{outline:2px solid #999;outline-offset:0}
.card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px}
.error{color:var(--bad);font-size:13.5px;margin-top:10px}
.pill{display:inline-block;background:var(--ink);color:#fff;border-radius:999px;font:700 12px/1 var(--sans);padding:5px 9px;vertical-align:middle}

/* ---- login ---- */
.login{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:20px}
.login-card{width:100%;max-width:360px;text-align:center;display:flex;flex-direction:column;gap:12px}
.login-card .logo{height:64px;width:auto;margin:0 auto 4px}
.login-card input{text-align:center}
.copyright{font-size:12px}

/* ---- topbar ---- */
.topbar{position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:16px;background:#fff;border-bottom:2px solid var(--ink);padding:10px 16px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:8px;font-weight:800;font-family:var(--serif)}
.brand img{height:30px}
.tabs{display:flex;gap:4px;flex:1;flex-wrap:wrap}
.tab{background:transparent;color:var(--mute);border:none;border-radius:8px;padding:8px 14px;font-weight:700}
.tab:hover{background:var(--soft);color:var(--ink)}
.tab.active{background:var(--ink);color:#fff}
.wrap{max-width:1000px;margin:0 auto;padding:20px 16px 60px}
.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:16px}
.toolbar input[type=search]{flex:1;min-width:180px}
.toolbar select{width:auto}

/* ---- lists / rows ---- */
.list{display:flex;flex-direction:column;gap:10px}
.row{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 16px;display:flex;gap:14px;align-items:center;cursor:pointer}
.row:hover{border-color:#aaa}
.row .grow{flex:1;min-width:0}
.row .title{font-weight:700}
.row .sub{color:var(--mute);font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.row .when{text-align:right;font-size:13px;color:var(--mute);white-space:nowrap}
.badge{display:inline-block;border-radius:999px;padding:4px 10px;font:700 11.5px/1 var(--sans);text-transform:uppercase;letter-spacing:.03em;border:1px solid}
.badge.new{color:#1a4f9a;border-color:#1a4f9a;background:#eef3fb}
.badge.confirmed{color:var(--warn);border-color:var(--warn);background:#fbf4e6}
.badge.fulfilled{color:var(--ok);border-color:var(--ok);background:#eef7f0}
.badge.canceled{color:var(--bad);border-color:var(--bad);background:#fbeeee;text-decoration:line-through}
.empty{padding:30px;text-align:center;color:var(--mute)}
.stars{font-size:15px;letter-spacing:1px}

/* ---- calendar ---- */
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-grid .dow{text-align:center;font:700 12px/1 var(--sans);color:var(--mute);padding:4px 0}
.cell{background:#fff;border:1px solid var(--line);border-radius:10px;min-height:74px;padding:6px 8px;display:flex;flex-direction:column;gap:4px;cursor:default}
.cell.pad{background:transparent;border:none}
.cell .d{font-weight:700;font-size:13px;color:var(--mute)}
.cell.today{outline:2px solid var(--ink)}
.cell.has{cursor:pointer}
.cell.has:hover{border-color:#888}
.cell .cnt{margin-top:auto;font:800 13px/1 var(--sans);background:var(--ink);color:#fff;border-radius:999px;padding:5px 8px;align-self:flex-start}
.cal-day{margin-top:18px}

/* ---- form grid ---- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:12px 0}
.form-grid label{display:flex;flex-direction:column;gap:5px;font:600 13px/1.3 var(--sans);color:var(--mute)}
.form-grid label.full{grid-column:1 / -1}

/* ---- drawer ---- */
.drawer{position:fixed;inset:0;z-index:20}
.drawer-bg{position:absolute;inset:0;background:rgba(0,0,0,.4)}
.drawer-panel{position:absolute;top:0;right:0;height:100%;width:min(460px,100%);background:#fff;box-shadow:-8px 0 30px rgba(0,0,0,.2);padding:22px;overflow:auto}
.drawer-close{position:absolute;top:14px;right:14px}
.kv{display:grid;grid-template-columns:auto 1fr;gap:6px 14px;margin:14px 0}
.kv dt{color:var(--mute);font:600 12px/1.4 var(--sans);text-transform:uppercase;letter-spacing:.03em}
.kv dd{margin:0;font-weight:500}
.actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px;border-top:1px solid var(--line);padding-top:16px}
.actions .danger{background:#fff;color:var(--bad);border-color:var(--bad)}

/* ---- toast ---- */
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;padding:12px 18px;border-radius:10px;font-weight:600;z-index:40;box-shadow:0 6px 20px rgba(0,0,0,.3)}

@media(max-width:560px){
  .form-grid{grid-template-columns:1fr}
  .cell{min-height:58px}
  .row{flex-wrap:wrap}
}
