@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;700;900&family=IBM+Plex+Sans:wght@400;500;600&display=swap');
:root {
  --ink:#1C1C1A; --ink-soft:#2E2E2B; --paper:#F7F6F2; --card:#FFFFFF;
  --brass:#C88A38; --brass-soft:#F6EDDC; --line:#E6E4DD; --text:#1C1C1A;
  --muted:#5C5C57; --primary:#A44A3F; --primary-hover:#8C3E34;
  --green:#2A453A; --green-bg:#E9EDEA; --blue:#2A453A;
  --blue-bg:#E9EDEA; --amber:#9A6A26; --amber-bg:#F7EFE1; --red:#A44A3F; --red-bg:#F4E7E5;
}
* { box-sizing:border-box; }
body { margin:0; background:var(--paper); color:var(--text);
  font:14px/1.55 'IBM Plex Sans', system-ui, -apple-system, sans-serif;
  -webkit-font-smoothing:antialiased; }
::selection { background:var(--brass); color:#fff; }
.serif { font-family:'Outfit', sans-serif; font-weight:700; letter-spacing:-0.01em; }
.eyebrow { font-size:11px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }
.wrap { max-width:1400px; margin:0 auto; padding:0 20px; }

/* ---- header: white bar, hard border, brand left / nav center / user right ---- */
header.app { background:var(--card); border-bottom:2px solid var(--line); position:sticky; top:0; z-index:40; }
header.app .inner { display:flex; align-items:center; gap:28px; padding:14px 20px; }
.brand { display:flex; align-items:center; gap:8px; flex:none; }
.brand .note { color:var(--primary); font-size:20px; line-height:1; }
.brand .brand-name { font-family:'Outfit', sans-serif; font-weight:900; font-size:18px; letter-spacing:-0.02em; color:var(--text); white-space:nowrap; }
.whoami { display:flex; flex-direction:column; align-items:flex-end; flex:none; margin-left:auto; min-width:0; }
.whoami .mail { font-size:13px; font-weight:500; color:var(--text); line-height:1.2;
  max-width:220px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.whoami .role { font-size:10px; font-weight:700; letter-spacing:.15em; text-transform:uppercase; color:var(--brass); margin-top:2px; white-space:nowrap; }
.whoami > div { margin-top:3px; white-space:nowrap; }
.whoami a, .whoami button { font-size:11px; color:var(--muted); background:none; border:none; padding:0;
  text-decoration:none; cursor:pointer; font-family:inherit; }
.whoami a:hover, .whoami button:hover { color:var(--primary); text-decoration:underline; }

nav.tabs { display:flex; gap:4px; flex:1; min-width:0; flex-wrap:nowrap; overflow-x:auto;
  scrollbar-width:none; -webkit-overflow-scrolling:touch; }
nav.tabs::-webkit-scrollbar { display:none; }
nav.tabs button { display:flex; align-items:center; gap:6px; padding:8px 12px; border-radius:3px; font-size:14px;
  font-weight:500; cursor:pointer; background:transparent; color:var(--muted); border:none; white-space:nowrap;
  flex:none; transition:background .2s ease-in-out, color .2s ease-in-out; font-family:inherit; }
nav.tabs button:hover { background:#F0EFE9; color:var(--text); }
nav.tabs button.active { background:var(--ink); color:#fff; }
nav.tabs button .cnt { opacity:.55; font-size:12px; }

/* Tablet & below: brand + user on the top row, tabs become a full-width scrollable strip */
@media (max-width: 1020px) {
  header.app .inner { flex-wrap:wrap; gap:0 16px; padding:12px 20px 0; }
  .brand { order:1; }
  .whoami { order:2; }
  nav.tabs { order:3; flex-basis:100%; margin:10px -20px 0; padding:0 20px 8px; width:calc(100% + 40px); }
}
@media (max-width: 560px) {
  header.app .inner { padding:10px 20px 0; }
  .brand .brand-name { font-size:16px; }
  .whoami .mail { max-width:150px; font-size:12px; }
  nav.tabs button { padding:7px 10px; font-size:13px; }
  .pagehead { margin:26px 0 20px; }
  .pagehead .page-h { font-size:30px; }
}

/* ---- page heading: eyebrow + big light Outfit title ---- */
.pagehead { margin:34px 0 26px; }
.pagehead .page-h { margin:2px 0 0; font-family:'Outfit', sans-serif; font-weight:300;
  font-size:38px; letter-spacing:-0.02em; line-height:1.05; color:var(--text); }
.pagehead .page-h strong { font-weight:900; }

.toolbar { display:flex; flex-wrap:wrap; gap:8px; align-items:center; margin-bottom:16px; }
.toolbar .spacer { flex:1; }
.savenote { font-size:11px; color:var(--muted); }
.savenote.err { color:var(--red); }

input, select, textarea { padding:8px 10px; border:1px solid #D6D3C9; border-radius:3px;
  font:inherit; color:var(--text); background:#fff; }
input:focus, select:focus, button:focus-visible { outline:2px solid rgba(200,138,56,.55); outline-offset:1px; }
label.f { display:block; }
label.f .l { display:block; font-size:11px; font-weight:700; letter-spacing:.15em;
  text-transform:uppercase; color:var(--muted); margin-bottom:5px; }
label.f input, label.f select { width:100%; }

button.btn { padding:8px 15px; border-radius:3px; font:inherit; font-size:14px; font-weight:500;
  cursor:pointer; background:#fff; border:1px solid #D6D3C9; color:var(--text);
  transition:all .2s ease-in-out; }
button.btn:hover { border-color:var(--muted); transform:translateY(-1px); color:var(--text); }
button.btn.brass { background:var(--primary); border-color:var(--primary); color:#fff; }
button.btn.brass:hover { background:var(--primary-hover); border-color:var(--primary-hover); color:#fff; }
button.btn.ink { background:var(--ink); border-color:var(--ink); color:#fff; }
button.btn.ink:hover { background:var(--ink-soft); color:#fff; }
button.btn.blue { background:var(--green); border-color:var(--green); color:#fff; }
button.btn.blue:hover { color:#fff; opacity:.92; }
button.btn.danger { background:var(--red); border-color:var(--red); color:#fff; }
button.btn.danger:hover { background:var(--primary-hover); color:#fff; }
button.btn.dangerline { color:var(--red); border-color:rgba(164,74,63,.35); }
button.btn.dangerline:hover { color:var(--red); border-color:var(--red); }
button.btn.ghost { border:none; background:none; color:var(--muted); }
button.btn.ghost:hover { color:var(--primary); transform:none; }
button.btn:disabled { opacity:.5; cursor:default; transform:none; }

.csvwrap { position:relative; }
.csvwrap .btn.open { border-color:var(--muted); }
.csvmenu { position:absolute; right:0; top:calc(100% + 4px); z-index:30; min-width:215px; background:#fff;
  border:1px solid #D6D3C9; border-radius:3px; box-shadow:0 6px 18px rgba(28,28,26,.14); overflow:hidden; }
.csvmenu button { display:block; width:100%; text-align:left; padding:9px 14px; background:#fff; border:none;
  border-bottom:1px solid var(--line); font:inherit; font-size:13px; color:var(--text); cursor:pointer; }
.csvmenu button:last-child { border-bottom:none; }
.csvmenu button:hover { background:#F0EFE9; color:var(--text); }

.card { background:var(--card); border:1px solid var(--line); border-radius:3px; }
.tablewrap { overflow-x:auto; }
table.inv { width:100%; border-collapse:collapse; font-size:14px; }
table.inv thead tr { background:var(--ink); }
table.inv th { text-align:left; padding:10px 12px; font-size:11px; letter-spacing:.08em;
  text-transform:uppercase; color:#F0EFE9; font-weight:700; white-space:nowrap; }
table.inv td { padding:10px 12px; border-bottom:1px solid var(--line); vertical-align:middle; }
table.inv tbody tr { cursor:pointer; transition:background .15s ease; }
table.inv tbody tr:nth-child(odd) { background:#FBFAF7; }
table.inv tbody tr:hover { background:#F0EFE9; }
table.inv tbody tr:last-child td { border-bottom:none; }
.sub { font-size:12px; color:var(--muted); }
.badge { display:inline-block; padding:2px 9px; border-radius:3px; font-size:11px; font-weight:700;
  letter-spacing:.05em; text-transform:uppercase; white-space:nowrap; border:1px solid transparent; }
.badge.Available { color:var(--green); background:rgba(42,69,58,.08); border-color:rgba(42,69,58,.3); }
.badge.Assigned { color:#9A6A26; background:rgba(200,138,56,.1); border-color:rgba(200,138,56,.4); }
.badge.InRepair { color:var(--red); background:rgba(164,74,63,.08); border-color:rgba(164,74,63,.3); }
.badge.Retired { color:var(--muted); background:#EEEDE8; border-color:var(--line); }
a.link { color:var(--green); cursor:pointer; text-decoration:underline; }
a.link:hover { color:var(--primary); }

.empty { text-align:center; padding:40px 20px 48px; color:var(--muted); }
.empty .empty-img { display:block; margin:0 auto 18px; width:100%; max-width:340px; height:170px;
  object-fit:cover; border-radius:3px; border:1px solid var(--line); filter:saturate(.85); }
.empty p { margin:0 0 12px; }

/* Modal */
.overlay { position:fixed; inset:0; background:rgba(28,28,26,.55); z-index:100;
  display:flex; align-items:flex-start; justify-content:center; padding:40px 16px; overflow-y:auto; }
.modal { background:var(--card); border-radius:3px; border:1px solid var(--line); border-top:3px solid var(--primary);
  width:100%; max-width:640px; padding:24px; }
.modal h2 { margin:0; font-size:22px; font-weight:700; font-family:'Outfit', sans-serif; letter-spacing:-0.01em; }
.modal .mhead { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; margin-bottom:8px; }
.modal .x { background:none; border:none; font-size:22px; line-height:1; cursor:pointer; color:var(--muted); }
.modal .x:hover { color:var(--primary); }
.ac-list { position:absolute; z-index:20; left:0; right:0; top:100%; margin-top:4px; background:#fff;
  border:1px solid #D6D3C9; border-radius:3px; box-shadow:0 6px 18px rgba(28,28,26,.14); overflow:hidden; }
.ac-item { display:flex; justify-content:space-between; align-items:center; gap:10px; width:100%; text-align:left;
  padding:8px 12px; background:#fff; border:none; border-bottom:1px solid var(--line); font:inherit; font-size:14px;
  color:var(--text); cursor:pointer; }
.ac-item:last-child { border-bottom:none; }
.ac-item:hover, .ac-item.hot { background:#F0EFE9; }
.msec { margin-top:22px; padding-top:16px; border-top:1px solid var(--line); }
.msec.first { margin-top:14px; padding-top:0; border-top:none; }
.msec-h { font-size:11px; font-weight:700; letter-spacing:.15em; text-transform:uppercase;
  color:var(--brass); margin-bottom:10px; }
.kv { display:flex; padding:6px 0; border-bottom:1px solid var(--line); }
.kv .k { width:170px; flex:none; font-size:11px; font-weight:600; color:var(--muted); text-transform:uppercase; letter-spacing:.06em; padding-top:3px; }
.kv .v { flex:1; }
.grid2 { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media (max-width:560px){ .grid2 { grid-template-columns:1fr; } }
.valuebox { margin-top:14px; padding:14px; border-radius:3px; background:var(--brass-soft); border:1px solid rgba(200,138,56,.3); }
.valuebox .amt { font-size:22px; font-weight:900; font-family:'Outfit', sans-serif; color:#9A6A26; }
.notice { font-size:12px; color:var(--amber); }
.assignbox { padding:16px; border-radius:3px; background:var(--green-bg); border:1px solid rgba(42,69,58,.25); }
.noteline { padding:10px 0; border-bottom:1px solid var(--line); }
.noteline .meta { display:flex; gap:8px; font-size:12px; color:var(--muted); }
.noteline .meta .t { font-weight:700; text-transform:uppercase; letter-spacing:.05em; font-size:11px; }
.noteline .meta .t.Repair { color:var(--red); }

/* Dashboard: hairline "control room" grid of stat tiles */
.tiles { display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:1px;
  background:var(--line); border:1px solid var(--line); border-radius:3px; overflow:hidden; margin-bottom:24px; }
.tile { background:var(--card); padding:20px; }
.tile .lbl { font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); font-weight:600; }
.tile .val { font-family:'Outfit', sans-serif; font-weight:900; font-size:32px; letter-spacing:-0.02em; margin-top:6px; line-height:1; }
.tile .val.brass { color:var(--brass); }
.feedhead { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin:28px 0 12px; }
.feedhead h3 { margin:0; font-size:22px; flex:1; font-weight:700; letter-spacing:-0.01em; }
.feed { padding:4px 18px 8px; }
.feedline { display:flex; gap:10px; padding:9px 0; border-bottom:1px solid var(--line); font-size:13px; }
.feedline:last-child { border-bottom:none; }
.feedline .when { flex:none; width:88px; color:var(--muted); font-size:12px; padding-top:1px; }
.feedline .who { color:var(--muted); }

/* Students */
.memgrid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:14px; }
.memcard { background:var(--card); border:1px solid var(--line); border-radius:3px; padding:18px; cursor:pointer;
  transition:all .2s ease-in-out; }
.memcard:hover { transform:translateY(-1px); border-color:#B9B6AA; box-shadow:0 1px 2px rgba(28,28,26,.06); }
.memcard .nm { font-family:'Outfit', sans-serif; font-weight:700; font-size:17px; letter-spacing:-0.01em; }
.memcard .chips { margin-top:8px; display:flex; flex-wrap:wrap; gap:6px; }
.chip { font-size:11px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; padding:2px 8px;
  border-radius:3px; background:var(--green-bg); color:var(--green); border:1px solid rgba(42,69,58,.25); }

/* School sites: dark context bar (like the district site bar) */
.sitebar { display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin:16px 0 -8px;
  padding:10px 16px; background:var(--ink); border-radius:3px; color:#fff; }
.sitebar .eyebrow { color:var(--brass); }
.sitebar strong { color:#fff; font-weight:700; }
.sitebar select { padding:6px 10px; background:#fff; }
.sitebar .btn.ghost { color:#C9C7BD; font-size:11px; letter-spacing:.1em; text-transform:uppercase; }
.sitebar .btn.ghost:hover { color:#fff; }
.chip.site { background:var(--brass-soft); color:#9A6A26; border-color:rgba(200,138,56,.4); }

/* Sign-in: split screen with hero image (left) and form (right) */
.gate { min-height:100vh; display:flex; align-items:center; justify-content:center; padding:24px; background:var(--paper); }
.gate .box { background:transparent; border:none; padding:0; width:100%; max-width:380px; }
.gate:not(.split) .box { background:var(--card); border:1px solid var(--line); border-top:3px solid var(--primary); border-radius:3px; padding:32px; }
.gate h1 { margin:0 0 22px; font-family:'Outfit', sans-serif; font-weight:300; font-size:28px; letter-spacing:-0.02em; }
.gate .field { margin-bottom:14px; }
.gate .err { color:var(--red); font-size:13px; margin-top:12px; padding:8px 12px;
  border:1px solid rgba(164,74,63,.3); background:rgba(164,74,63,.05); border-radius:3px; }
.gate.split { display:grid; grid-template-columns:1fr 1fr; align-items:stretch; padding:0; }
.ghero { position:relative; display:flex; flex-direction:column; justify-content:space-between; padding:48px;
  color:#fff; background:
    linear-gradient(rgba(28,28,26,.5), rgba(28,28,26,.5)),
    url("https://images.unsplash.com/photo-1573871666457-7c7329118cf9?crop=entropy&cs=srgb&fm=jpg&ixid=M3w4NjA1MDZ8MHwxfHNlYXJjaHwyfHx2aW50YWdlJTIwYnJhc3MlMjBpbnN0cnVtZW50fGVufDB8fHx8MTc4MjIzNDkxOXww&ixlib=rb-4.1.0&q=85") center/cover no-repeat, var(--ink); }
.ghero .brand .brand-name { color:#fff; font-size:20px; }
.ghero .brand .note { color:var(--brass); }
.ghead { margin:0; font-family:'Outfit', sans-serif; font-weight:300; font-size:48px; line-height:1.02; letter-spacing:-0.02em; }
.ghead strong { font-weight:900; }
.ghero p { margin:22px 0 0; max-width:420px; color:#E4E2DB; line-height:1.65; font-size:15px; }
.gform { display:flex; align-items:center; justify-content:center; padding:32px; background:var(--paper); }
.gform .brand { margin-bottom:36px; display:none; }
.gform .gh2 { margin:4px 0 26px; font-family:'Outfit', sans-serif; font-weight:300; font-size:30px; letter-spacing:-0.02em; }
@media (max-width:900px){
  .gate.split { grid-template-columns:1fr; }
  .ghero { display:none; }
  .gform { min-height:100vh; }
  .gform .brand { display:flex; }
}

footer.app { padding:24px 0 40px; text-align:center; font-size:12px; color:var(--muted);
  background:transparent; border:none; position:static; }
@media print { body * { visibility:hidden; } }

/* ==================================================================
   Admin page (admin.html) — all rules scoped under body.admin
   ================================================================== */
body.admin {
    --paper:   #F7F6F2;
    --ink:     #1C1C1A;
    --muted:   #5C5C57;
    --line:    #E6E4DD;
    --velvet:  #A44A3F; /* terracotta: the primary accent */
    --velvet-soft: #F4E7E5;
    --brass:   #C88A38;
    --ok:      #2A453A;
  }
body.admin * { box-sizing: border-box; }
body.admin {
    margin: 0;
    background: var(--paper);
    color: var(--ink);
    font-family: "IBM Plex Sans", system-ui, sans-serif;
    font-size: 15px;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
  }
body.admin ::selection { background: var(--brass); color: #fff; }
body.admin .wrap { max-width: 880px; margin: 0 auto; padding: 0 20px 80px; }
body.admin header {
    border-bottom: 2px solid var(--line);
    padding: 30px 0 18px;
    margin-bottom: 32px;
    display: flex; align-items: baseline; justify-content: space-between; gap: 16px; flex-wrap: wrap;
  }
body.admin .wordmark { font-family: "Outfit", sans-serif; font-weight: 900; font-size: 24px; letter-spacing: -0.02em; }
body.admin .wordmark::before { content: "\266A  "; color: var(--velvet); font-weight: 400; }
body.admin .wordmark small {
    display: block; font-family: "IBM Plex Sans", sans-serif; font-weight: 700;
    font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--brass); margin-top: 5px;
  }
body.admin .whoami { font-size: 13px; color: var(--muted); text-align: right; }
body.admin .whoami button { margin-left: 10px; }
body.admin h2 { font-family: "Outfit", sans-serif; font-weight: 700; font-size: 21px; letter-spacing: -0.01em; margin: 0 0 14px; }
body.admin .card { border: 1px solid var(--line); border-radius: 3px; padding: 22px; background: #fff; margin-bottom: 28px; }
body.admin label { display: block; font-size: 11px; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase; color: var(--muted); margin-bottom: 5px; }
body.admin input, body.admin select {
    width: 100%; padding: 9px 11px; border: 1px solid #D6D3C9; border-radius: 3px;
    font: inherit; color: var(--ink); background: #fff;
  }
body.admin input:focus, body.admin select:focus, body.admin button:focus-visible { outline: 2px solid rgba(200,138,56,.55); outline-offset: 1px; }
body.admin button {
    font: inherit; font-weight: 500; cursor: pointer; border-radius: 3px;
    border: 1px solid #D6D3C9; background: #fff; color: var(--ink); padding: 9px 16px;
    transition: all .2s ease-in-out;
  }
body.admin button:hover { border-color: var(--muted); transform: translateY(-1px); color: var(--ink); }
body.admin button.primary { background: var(--velvet); border-color: var(--velvet); color: #fff; }
body.admin button.primary:hover { background: #8C3E34; border-color: #8C3E34; color: #fff; }
body.admin button.quiet { border: none; background: none; padding: 6px 8px; font-weight: 500; color: var(--muted); }
body.admin button.quiet:hover { color: var(--velvet); transform: none; }
body.admin button.danger:hover { color: #fff; background: var(--velvet); border-color: var(--velvet); }
body.admin button:disabled { opacity: 0.5; cursor: wait; transform: none; }
body.admin .grid { display: grid; grid-template-columns: 2fr 2fr 1fr 1.4fr auto; gap: 12px; align-items: end; }
@media (max-width: 640px) {
body.admin .grid { grid-template-columns: 1fr; }
}
body.admin table { width: 100%; border-collapse: collapse; }
body.admin th { text-align: left; font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: #F0EFE9; background: var(--ink); font-weight: 700; padding: 9px 10px; }
body.admin td { padding: 10px; border-bottom: 1px solid var(--line); vertical-align: middle; }
body.admin tbody tr:nth-child(odd) { background: #FBFAF7; }
body.admin tr:last-child td { border-bottom: none; }
body.admin td.actions { text-align: right; white-space: nowrap; }
body.admin .badge {
    display: inline-block; font-size: 11px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
    padding: 2px 9px; border-radius: 3px; border: 1px solid var(--line); color: var(--muted);
  }
body.admin .badge.admin { background: rgba(164,74,63,.08); border-color: rgba(164,74,63,.35); color: var(--velvet); }
body.admin .dim { color: var(--muted); font-size: 13px; }
body.admin .msg { border-radius: 3px; padding: 10px 14px; margin: 0 0 18px; font-size: 14px; display: none; }
body.admin .msg.error { display: block; background: var(--velvet-soft); border: 1px solid rgba(164,74,63,.4); color: var(--velvet); }
body.admin .msg.ok { display: block; background: #E9EDEA; border: 1px solid rgba(42,69,58,.4); color: var(--ok); }
body.admin .center { max-width: 380px; margin: 10vh auto 0; }
body.admin .center .card { padding: 28px; border-top: 3px solid var(--velvet); }
body.admin .center h2 { margin-bottom: 20px; font-weight: 300; font-size: 26px; }
body.admin .field { margin-bottom: 14px; }
body.admin .hidden { display: none !important; }
