:root{
  --paper:#F4F1EA;
  --paper-2:#FBFAF7;
  --paper-3:#EDE8DC;
  --ink:#1A1814;
  --ink-2:#3A352D;
  --muted:#6B655A;
  --faint:#94907F;
  --line:#D9D3C5;
  --line-2:#C7C0AE;
  --oxblood:#8B2E2E;
  --amber:#B88A1F;
  --forest:#2F5C4F;
  --slate:#5A6470;
  --serif:'Fraunces',Georgia,serif;
  --sans:'IBM Plex Sans',-apple-system,BlinkMacSystemFont,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased}
body{
  background:
    radial-gradient(circle at 15% 10%, rgba(184,138,31,0.04), transparent 40%),
    radial-gradient(circle at 85% 90%, rgba(139,46,46,0.03), transparent 40%),
    var(--paper);
  min-height:100vh;
  padding:0 0 80px;
}
a{color:var(--ink-2);text-decoration:none}
a.textlink{border-bottom:1px solid var(--line-2);color:var(--ink-2)}
a.textlink:hover{border-color:var(--ink)}

/* LOGIN */
.login-view{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{max-width:420px;width:100%;background:var(--paper-2);border:1px solid var(--line);padding:38px 32px;border-radius:2px;box-shadow:0 30px 60px -20px rgba(26,24,20,0.15)}
.login-card .eyebrow{margin-bottom:14px}
.login-title{font-family:var(--serif);font-weight:500;font-size:44px;line-height:1.02;letter-spacing:-0.02em;margin-bottom:6px}
.login-title em{font-style:italic;font-weight:400;color:var(--ink-2)}
.login-sub{color:var(--muted);font-size:13px;margin-bottom:24px;max-width:340px}
.login-error{color:var(--oxblood);font-size:12.5px;min-height:18px;margin-bottom:10px;font-family:var(--mono);letter-spacing:0.02em}

.wrap{max-width:1180px;margin:0 auto;padding:32px 28px 0}

header.masthead{border-bottom:1px solid var(--line);padding-bottom:24px;margin-bottom:28px;position:relative}
.eyebrow{font-family:var(--mono);font-size:10.5px;letter-spacing:0.22em;text-transform:uppercase;color:var(--muted);margin-bottom:10px;display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.eyebrow .dot{width:5px;height:5px;border-radius:50%;background:var(--oxblood);display:inline-block}
h1{font-family:var(--serif);font-weight:500;font-size:clamp(34px,4.4vw,52px);line-height:1.02;letter-spacing:-0.02em;color:var(--ink)}
h1 em{font-style:italic;font-weight:400;color:var(--ink-2)}
.sub{margin-top:14px;color:var(--muted);font-size:14px;max-width:680px}

.overall{margin-top:22px;display:grid;grid-template-columns:1fr auto;gap:18px;align-items:end}
.pbar-wrap{flex:1}
.pbar-label{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px;font-family:var(--mono);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted)}
.pbar-label .big{font-family:var(--serif);font-size:18px;letter-spacing:-0.01em;text-transform:none;color:var(--ink);font-weight:500}
.pbar{height:6px;background:var(--paper-3);border-radius:1px;overflow:hidden}
.pbar > div{height:100%;background:linear-gradient(90deg,var(--forest),#3E7060);transition:width 600ms cubic-bezier(.2,.7,.2,1)}
.dropbox-badge{font-family:var(--mono);font-size:10.5px;letter-spacing:0.1em;text-transform:uppercase;color:var(--faint)}
.dropbox-badge.ok{color:var(--forest)}
.dropbox-badge.off{color:var(--oxblood)}
.topbtns{display:flex;gap:8px;align-items:end;flex-wrap:wrap}

.btn{
  font-family:var(--sans);font-weight:500;font-size:12.5px;letter-spacing:0.01em;
  background:var(--ink);color:var(--paper);border:1px solid var(--ink);
  padding:9px 14px;border-radius:2px;cursor:pointer;transition:all 160ms ease;
  display:inline-flex;align-items:center;gap:7px;
}
.btn:hover{background:var(--ink-2);transform:translateY(-1px)}
.btn.ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn.ghost:hover{background:var(--paper-2);border-color:var(--ink-2)}
.btn.danger{background:transparent;color:var(--oxblood);border-color:var(--oxblood)}
.btn.danger:hover{background:var(--oxblood);color:var(--paper)}
.btn.sm{padding:6px 10px;font-size:11.5px}
.btn.block{width:100%;justify-content:center;padding:11px}
.btn svg{width:13px;height:13px}

.people-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);margin-bottom:28px;border-radius:2px;overflow:hidden}
.pcard{background:var(--paper-2);padding:12px 14px;cursor:pointer;transition:background 160ms}
.pcard:hover{background:var(--paper)}
.pcard.active{background:var(--ink);color:var(--paper)}
.pcard.active .pname,.pcard.active .pstat{color:var(--paper)}
.pcard.active .pstat b{color:var(--paper)}
.pname{font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:0.12em;color:var(--muted);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pstat{font-family:var(--serif);font-size:20px;font-weight:500;color:var(--ink);letter-spacing:-0.01em}
.pstat b{font-weight:500}
.pstat .of{color:var(--faint);font-size:13px}

.filters{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-bottom:24px;padding:14px 16px;background:var(--paper-2);border:1px solid var(--line);border-radius:2px}
.filters > .lbl{font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:0.14em;color:var(--muted)}
.pills{display:flex;gap:4px;flex-wrap:wrap}
.pill{font-family:var(--mono);font-size:11px;letter-spacing:0.05em;text-transform:uppercase;padding:5px 10px;border-radius:2px;cursor:pointer;border:1px solid transparent;color:var(--muted);transition:all 140ms}
.pill:hover{color:var(--ink)}
.pill.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.pill .ct{opacity:0.55;margin-left:4px}
input.search{flex:1;min-width:200px;border:none;border-bottom:1px solid var(--line-2);background:transparent;padding:6px 0;font-family:var(--sans);font-size:13px;color:var(--ink);outline:none}
input.search:focus{border-color:var(--ink)}

.category{margin-bottom:22px;background:var(--paper-2);border:1px solid var(--line);border-radius:2px;overflow:hidden}
.cathead{display:grid;grid-template-columns:auto 1fr auto auto;gap:18px;align-items:center;padding:18px 22px;cursor:pointer;border-bottom:1px solid transparent;transition:all 180ms}
.category.open .cathead{border-bottom-color:var(--line)}
.cathead:hover{background:var(--paper)}
.catnum{font-family:var(--serif);font-style:italic;font-size:28px;font-weight:400;color:var(--oxblood);min-width:46px;line-height:1}
.cattitle{font-family:var(--serif);font-size:19px;font-weight:500;letter-spacing:-0.01em;color:var(--ink)}
.catdesc{font-size:12.5px;color:var(--muted);margin-top:2px}
.catprog{font-family:var(--mono);font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:0.1em;text-align:right}
.catprog b{font-family:var(--serif);font-size:18px;color:var(--ink);font-weight:500;letter-spacing:-0.01em;display:block;text-transform:none}
.catchev{color:var(--faint);transition:transform 220ms}
.category.open .catchev{transform:rotate(90deg)}
.catitems{padding:4px 0 6px;display:none}
.category.open .catitems{display:block}

.item{display:grid;grid-template-columns:32px 1fr auto auto;gap:14px;align-items:center;padding:10px 22px;border-bottom:1px solid var(--line);transition:background 120ms}
.item:last-child{border-bottom:none}
.item:hover{background:var(--paper)}
.item.expanded{background:var(--paper)}
.status-dot{width:14px;height:14px;border-radius:50%;border:1.5px solid var(--line-2);background:transparent;cursor:pointer;transition:all 160ms;position:relative}
.status-dot:hover{transform:scale(1.15)}
.status-dot.in_progress{border-color:var(--amber);background:var(--amber)}
.status-dot.complete{border-color:var(--forest);background:var(--forest)}
.status-dot.complete::after{content:'';position:absolute;left:3px;top:1px;width:4px;height:7px;border:solid var(--paper);border-width:0 1.5px 1.5px 0;transform:rotate(45deg)}
.status-dot.na{border-color:var(--slate);background:var(--slate);opacity:0.5}
.status-dot.na::after{content:'';position:absolute;left:3px;top:5.5px;width:6px;height:1.5px;background:var(--paper)}
.itemtitle{font-size:13.5px;color:var(--ink);line-height:1.4;font-weight:500}
.item.complete .itemtitle,.item.na .itemtitle{color:var(--faint);text-decoration:line-through}
.itemdesc{font-size:12px;color:var(--muted);margin-top:2px;line-height:1.45}
.badges{display:flex;gap:6px;align-items:center}
.badge{font-family:var(--mono);font-size:10.5px;letter-spacing:0.05em;text-transform:uppercase;padding:3px 7px;border-radius:2px;background:var(--paper-3);color:var(--muted);border:1px solid var(--line);white-space:nowrap}
.badge.assignee{background:transparent;color:var(--ink-2);border-color:var(--line-2)}
.badge.docs{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.badge.docs.zero{background:transparent;color:var(--faint);border-color:var(--line)}
.item-expand{color:var(--faint);cursor:pointer;font-size:13px;line-height:1;transition:transform 180ms;padding:4px}
.item.expanded .item-expand{transform:rotate(90deg)}

.itemdetail{display:none;padding:4px 22px 22px 68px;background:var(--paper);border-bottom:1px solid var(--line);font-size:13px}
.item.expanded + .itemdetail{display:block}
.detail-row{display:grid;grid-template-columns:120px 1fr;gap:14px;padding:8px 0;border-top:1px dashed var(--line-2)}
.detail-row:first-child{border-top:none}
.detail-label{font-family:var(--mono);font-size:10.5px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);padding-top:3px}
.detail-val{color:var(--ink-2)}
.detail-val textarea,.detail-val select,.detail-val input{width:100%;font-family:var(--sans);font-size:13px;color:var(--ink);background:transparent;border:1px solid var(--line-2);border-radius:2px;padding:7px 10px;outline:none;resize:vertical}
.detail-val textarea:focus,.detail-val select:focus,.detail-val input:focus{border-color:var(--ink)}
.detail-folder{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11.5px;color:var(--muted);padding:6px 0}
.detail-folder code{background:var(--paper-3);padding:2px 6px;border-radius:2px}
.doclist{display:flex;flex-direction:column;gap:6px}
.doc{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;padding:8px 12px;background:var(--paper-2);border:1px solid var(--line);border-radius:2px}
.doc .fname{font-weight:500;color:var(--ink);font-size:13px;word-break:break-word}
.doc .fmeta{font-family:var(--mono);font-size:10.5px;color:var(--muted);letter-spacing:0.05em;text-transform:uppercase;margin-top:2px}
.doc .fnote{font-size:12px;color:var(--muted);margin-top:3px;font-style:italic}
.doc a.dlink{color:var(--oxblood);font-size:11.5px;text-decoration:none;border-bottom:1px solid currentColor}
.doc a.dlink:hover{color:var(--ink)}
.docicon{width:22px;height:22px;color:var(--muted)}
.doc .rmdoc{background:none;border:none;color:var(--faint);cursor:pointer;font-size:14px;padding:2px 6px}
.doc .rmdoc:hover{color:var(--oxblood)}
.addbtns{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}

/* MODAL */
.modal-back{position:fixed;inset:0;background:rgba(26,24,20,0.55);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:100;padding:20px;overflow:auto}
.modal-back.show{display:flex;animation:fadein 180ms ease}
@keyframes fadein{from{opacity:0}to{opacity:1}}
.modal{background:var(--paper);border:1px solid var(--line-2);border-radius:3px;max-width:540px;width:100%;padding:28px 28px 22px;box-shadow:0 20px 60px -10px rgba(26,24,20,0.4);max-height:90vh;overflow:auto}
.modal.wide{max-width:680px}
.modal h2{font-family:var(--serif);font-weight:500;font-size:24px;letter-spacing:-0.01em;margin-bottom:6px}
.modal h3.modal-h3{font-family:var(--serif);font-weight:500;font-size:17px;letter-spacing:-0.01em;margin-bottom:10px}
.modal hr.modal-rule{border:none;border-top:1px solid var(--line);margin:20px 0 16px}
.modal .msub{color:var(--muted);font-size:12.5px;margin-bottom:18px}
.field{margin-bottom:14px}
.field label{display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;font-family:var(--sans);font-size:13.5px;color:var(--ink);background:var(--paper-2);border:1px solid var(--line-2);border-radius:2px;padding:9px 12px;outline:none}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--ink);background:var(--paper)}
.field textarea{min-height:60px;resize:vertical}
.field.two-col{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field.two-col > div > label{display:block}
.checkrow{display:flex;flex-direction:column;gap:8px}
.checkrow label{text-transform:none;letter-spacing:normal;font-family:var(--sans);font-size:13px;color:var(--ink-2);display:flex;align-items:center;gap:8px;cursor:pointer}
.checkrow input{width:auto;margin:0}
.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}

.dbx-status{background:var(--paper-2);border:1px solid var(--line);padding:12px 14px;border-radius:2px;margin-bottom:10px;font-size:13px;color:var(--ink-2)}
.dbx-status .dbx-row{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.dbx-status code{background:var(--paper-3);padding:2px 6px;border-radius:2px;font-family:var(--mono);font-size:11.5px}

/* PEOPLE MANAGER */
.people-list{display:flex;flex-direction:column;gap:6px;margin-bottom:8px;max-height:300px;overflow:auto}
.person-row{display:grid;grid-template-columns:1fr auto auto auto;gap:10px;align-items:center;padding:8px 12px;background:var(--paper-2);border:1px solid var(--line);border-radius:2px}
.person-row .pn{font-weight:500;color:var(--ink)}
.person-row .pe{font-family:var(--mono);font-size:11px;color:var(--muted)}
.person-row button{background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;font-size:13px}
.person-row button:hover{color:var(--ink)}
.person-row button.del:hover{color:var(--oxblood)}

.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--ink);color:var(--paper);padding:11px 20px;border-radius:2px;font-size:12.5px;font-family:var(--mono);letter-spacing:0.05em;text-transform:uppercase;z-index:200;opacity:0;pointer-events:none;transition:all 280ms ease}
.toast.show{opacity:1;transform:translateX(-50%) translateY(-6px)}

footer{margin-top:42px;padding-top:22px;border-top:1px solid var(--line);text-align:center;font-family:var(--mono);font-size:10.5px;letter-spacing:0.15em;text-transform:uppercase;color:var(--faint)}

.loading{padding:80px 20px;text-align:center;color:var(--muted);font-family:var(--mono);font-size:12px;letter-spacing:0.1em;text-transform:uppercase}

@media (max-width:760px){
  .wrap{padding:22px 16px 0}
  .item{grid-template-columns:24px 1fr auto;padding:10px 14px}
  .item .badges{display:none}
  .itemdetail{padding-left:46px;padding-right:14px}
  .cathead{padding:14px 16px;gap:12px}
  .catnum{font-size:24px;min-width:32px}
  .overall{grid-template-columns:1fr}
  .topbtns{justify-content:flex-start}
  .field.two-col{grid-template-columns:1fr}
}
