:root{
  --bg:#faf8f4; --surface:#ffffff; --surface-2:#f4f0e9; --surface-3:#efe9e0;
  --border:rgba(40,30,20,.10); --border-strong:rgba(40,30,20,.16);
  --text:#20201d; --muted:#6f6b63; --hint:#9b968c;
  --accent:#bd5d3a; --accent-dark:#a44d2e; --accent-soft:#f8ece5; --accent-border:#e6c3b2;
  --danger:#b23b3b; --danger-soft:#fbe9e9;
  --radius:14px; --radius-sm:10px; --radius-pill:999px;
  --shadow:0 1px 2px rgba(40,30,20,.04), 0 4px 16px rgba(40,30,20,.05);
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:var(--font);background:var(--bg);color:var(--text);
  font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
h1{font-size:22px;font-weight:650;letter-spacing:-.01em;margin:0 0 6px}
h2{font-size:15px;font-weight:650;margin:0 0 14px;letter-spacing:-.005em}
.wrap{max-width:1020px;margin:0 auto;padding:28px 22px 60px}
.spacer{flex:1}
.muted{color:var(--hint);font-size:12px}
.lead{color:var(--muted);font-size:14px;margin:0 0 4px}
.sub{color:var(--hint);font-size:13px;margin:0 0 18px}
.center{text-align:center}

/* App bar */
.appbar{display:flex;align-items:center;gap:20px;padding:13px 24px;
  background:var(--surface);border-bottom:1px solid var(--border)}
.brand{display:flex;align-items:center;gap:9px;font-weight:650;color:var(--text);font-size:15px}
.brand:hover{text-decoration:none}
.brand-badge{width:30px;height:30px;border-radius:9px;background:var(--accent);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px}
.appnav{display:flex;gap:18px}
.appnav a{color:var(--muted);font-weight:500}
.appnav a:hover{color:var(--text);text-decoration:none}
.appbar-right{margin-left:auto;display:flex;align-items:center;gap:16px}
.bell{position:relative;font-size:17px;line-height:1}
.bell:hover{text-decoration:none}
.bell .badge{position:absolute;top:-7px;right:-9px;background:var(--accent);color:#fff;
  font-size:10px;font-weight:600;border-radius:var(--radius-pill);padding:1px 5px;line-height:1.4}
.avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-soft);color:var(--accent-dark);
  display:flex;align-items:center;justify-content:center;font-weight:650;font-size:12px}
.logout{color:var(--hint);font-size:17px}.logout:hover{color:var(--text);text-decoration:none}

/* Cards */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:22px;margin-bottom:18px;box-shadow:var(--shadow)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 15px;border-radius:var(--radius-sm);
  border:1px solid var(--border-strong);background:var(--surface);color:var(--text);
  cursor:pointer;font-size:13px;font-weight:550;font-family:inherit;transition:.12s;white-space:nowrap}
.btn:hover{background:var(--surface-2);text-decoration:none}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary:hover{background:var(--accent-dark)}
.btn-ghost{border-color:transparent;background:transparent;color:var(--muted)}
.btn-ghost:hover{background:var(--surface-2);color:var(--text)}
.btn-sm{padding:6px 12px;font-size:12.5px}
.btn-add{cursor:pointer}

/* Forms */
.field{margin-bottom:14px}
label{display:block;font-size:12px;font-weight:550;color:var(--muted);margin-bottom:6px}
input,select,textarea{width:100%;padding:10px 12px;border:1px solid var(--border-strong);
  border-radius:var(--radius-sm);font-size:13.5px;font-family:inherit;background:var(--surface);
  color:var(--text);transition:.12s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-soft)}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%236f6b63' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:34px}

/* Lists / search */
.toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.toolbar h1{margin:0}
.search{max-width:320px}
.count{color:var(--hint);font-size:12.5px}

/* Table */
.table-card{padding:6px 10px}
table{width:100%;border-collapse:collapse}
th{text-align:left;padding:11px 12px;font-size:11.5px;color:var(--hint);font-weight:600;
  text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border-strong)}
td{padding:13px 12px;border-bottom:1px solid var(--border);vertical-align:middle}
tbody tr{cursor:pointer;transition:.1s}
tbody tr:hover{background:var(--surface-2)}
tbody tr:last-child td{border-bottom:none}
.zid{color:var(--accent-dark);font-weight:600;font-variant-numeric:tabular-nums}
.td-name strong{font-weight:600}.td-name .muted{margin-top:2px}
.over{color:var(--danger);font-weight:600}

/* Status pills */
.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;border-radius:var(--radius-pill);
  font-size:11.5px;font-weight:600;white-space:nowrap}
.pill .d{width:7px;height:7px;border-radius:50%}

/* Project picker */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.pcard{border:1px solid var(--border);border-radius:var(--radius);padding:18px;
  background:var(--surface);box-shadow:var(--shadow);transition:.13s;display:block;color:var(--text)}
.pcard:hover{border-color:var(--accent-border);transform:translateY(-1px);text-decoration:none}
.pc-name{font-weight:650;font-size:15px}
.pc-lok{color:var(--hint);font-size:12.5px;margin:3px 0 14px}
.stat{display:inline-block;font-size:11.5px;font-weight:600;padding:4px 11px;border-radius:var(--radius-pill);
  background:var(--accent-soft);color:var(--accent-dark)}

/* Order detail */
.detail-top{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.nav-group{display:inline-flex;align-items:center;border:1px solid var(--border-strong);
  border-radius:var(--radius-sm);overflow:hidden;background:var(--surface)}
.nav-group a,.nav-group span{padding:6px 11px;color:var(--muted);font-size:14px}
.nav-group a:hover{background:var(--surface-2);text-decoration:none}
.nav-group .disabled{color:var(--border-strong)}
.nav-pos{font-size:12px;font-variant-numeric:tabular-nums;border-left:1px solid var(--border);border-right:1px solid var(--border)}
.order-head-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.zid-badge{font-size:12px;font-weight:650;color:var(--accent-dark);background:var(--accent-soft);
  padding:4px 11px;border-radius:var(--radius-pill);font-variant-numeric:tabular-nums}
.facts{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-top:18px}
.fact{background:var(--surface-2);border-radius:var(--radius-sm);padding:13px 15px}
.fact .l{font-size:11px;font-weight:600;color:var(--hint);text-transform:uppercase;letter-spacing:.03em;margin-bottom:6px}
.fact .v{font-size:14px;font-weight:500}
.contact{margin-top:7px;display:flex;flex-direction:column;gap:2px;font-size:12.5px}

/* Status change form */
.status-row{display:flex;align-items:flex-end;gap:12px;margin-bottom:14px}
.status-row .field{flex:1;margin-bottom:0;max-width:280px}

/* Documents */
.folder{border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:12px;overflow:hidden}
.folder-head{display:flex;align-items:center;gap:10px;padding:11px 15px;background:var(--surface-2)}
.folder-name{font-weight:600;font-size:13px}
.folder-count{font-size:11px;font-weight:600;color:var(--muted);background:var(--surface);
  border:1px solid var(--border);border-radius:var(--radius-pill);padding:1px 8px}
.folder-upload{margin-left:auto}
.docrow{display:flex;align-items:center;gap:11px;padding:11px 15px;border-top:1px solid var(--border)}
.doc-icon{color:var(--hint)}
.doc-name{flex:1;font-size:13px}
.doc-meta{color:var(--hint);font-size:11.5px}
.docrow.empty{color:var(--hint);font-size:12.5px;justify-content:flex-start}
.hist-dot{width:7px;height:7px;border-radius:50%;background:var(--accent-border);flex:none}

/* Messages */
.msg{padding:11px 15px;border-radius:var(--radius-sm);margin-bottom:14px;font-size:13px;font-weight:500}
.msg-success{background:#e6f3ec;color:#1d6f4f}
.msg-error{background:var(--danger-soft);color:var(--danger)}
.msg-info{background:var(--accent-soft);color:var(--accent-dark)}

/* Login */
.login-stage{min-height:82vh;display:flex;align-items:center;justify-content:center}
.login-card{width:100%;max-width:370px}
.login-card .brand-badge{width:54px;height:54px;font-size:24px;border-radius:14px;margin:0 auto 12px}

/* Util */
.row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.archived-tag{font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:var(--radius-pill);
  background:var(--surface-3);color:var(--muted)}

/* Full-width list */
.wrap-wide{max-width:none;padding-left:30px;padding-right:30px}

/* Sortable headers */
th.sortable{cursor:pointer;user-select:none}
th.sortable:hover{color:var(--text)}
th .arrow{opacity:.5;font-size:10px;margin-left:3px}
th.active{color:var(--accent-dark)}
th.active .arrow{opacity:1}

/* User / project management */
.list-table td .role-tag{font-size:11px;font-weight:600;padding:2px 9px;border-radius:var(--radius-pill);
  background:var(--surface-2);color:var(--muted)}
.inactive-row{opacity:.5}
.chip{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;padding:3px 9px;
  border-radius:var(--radius-pill);background:var(--surface-2);color:var(--muted);margin:2px}
.proj-actions{display:flex;gap:6px;margin-top:12px;flex-wrap:wrap}
.checks{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px;
  border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;max-height:280px;overflow:auto}
.checks label{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text);margin:0;font-weight:450;cursor:pointer}
.checks input{width:auto}
.help{font-size:12px;color:var(--hint);margin:6px 0 0}
.form-narrow{max-width:560px}
.danger-text{color:var(--danger)}
