:root{--ink: #1a1a1a;--ink-light: #4a4a4a;--ink-lighter: #7a7a7a;--ink-faint: #b0b0b0;--bg: #fffff8;--bg-warm: #fafaf2;--accent: #8b0000;--rule: #e0ddd4;--rule-strong: #c8c4b8;--sidebar-bg: #f5f4ee;--font-body: "Crimson Pro", Georgia, serif;--font-ui: "Source Sans 3", "Source Sans Pro", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--success: #2d6a2e;--success-bg: #f0f8f0;--error: #8b0000;--error-bg: #fdf2f2}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background:var(--bg);color:var(--ink);line-height:1.6;min-height:100vh}.app-shell{min-height:100vh;display:flex;flex-direction:column}.masthead{border-bottom:1px solid var(--rule);background:var(--bg);padding:1rem 1.5rem}.masthead-inner{max-width:960px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.masthead-title{font-family:var(--font-ui);font-size:.72rem;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--ink);line-height:1.2}.masthead-subtitle{font-family:var(--font-body);font-size:1.1rem;color:var(--ink-light);margin-top:.1rem}.masthead-right{display:flex;align-items:center;gap:.75rem}.masthead-user{font-family:var(--font-ui);font-size:.8rem;color:var(--ink-lighter)}.btn-logout{font-size:.65rem;padding:.3rem .6rem}.main-content{flex:1;max-width:960px;width:100%;margin:0 auto;padding:2rem 1.5rem 3rem}.btn{font-family:var(--font-ui);font-size:.72rem;font-weight:600;letter-spacing:.8px;text-transform:uppercase;padding:.5rem 1rem;border:1px solid var(--rule-strong);border-radius:0;background:var(--bg);color:var(--ink-light);cursor:pointer;transition:background .15s,border-color .15s;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:.4rem}.btn:hover{background:var(--sidebar-bg)}.btn-primary{background:var(--ink);border-color:var(--ink);color:var(--bg)}.btn-primary:hover{background:var(--ink-light)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn:disabled:hover{background:var(--bg)}.btn-primary:disabled:hover{background:var(--ink)}.btn-back{background:transparent;border-color:var(--rule);color:var(--ink-lighter)}.btn-back:hover{background:var(--sidebar-bg)}.btn-full{width:100%}.btn-sm{font-size:.62rem;padding:.25rem .5rem;letter-spacing:.5px}.btn-danger{background:var(--error);border-color:var(--error);color:#fff}.btn-danger:hover{background:#6b0000}.login-container{max-width:340px;margin:4.5rem auto 0}.login-heading{font-family:var(--font-body);font-size:1.8rem;font-weight:400;color:var(--ink);margin-bottom:.25rem;letter-spacing:.01em}.login-rule{width:2rem;height:0;border:none;border-top:1px solid var(--rule-strong);margin:.8rem 0 .9rem}.login-subtext{font-family:var(--font-body);font-size:1rem;font-style:italic;color:var(--ink-lighter);margin-bottom:2rem;line-height:1.55}.login-form{display:flex;flex-direction:column;gap:1.25rem}.login-form .form-field label{font-family:var(--font-body);font-size:.85rem;font-weight:400;letter-spacing:0;text-transform:none;color:var(--ink-light);font-variant:small-caps}.login-form .btn-primary{margin-top:.5rem;padding:.6rem 1rem;font-size:.7rem;letter-spacing:1.2px;transition:opacity .2s}.login-form .btn-primary:hover{opacity:.8;background:var(--ink)}.form-field{display:flex;flex-direction:column;gap:.3rem}.form-field label{font-family:var(--font-ui);font-size:.72rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--ink-lighter);display:flex;align-items:center;gap:.4rem}.form-field input,.form-field select,.form-field textarea{font-family:var(--font-body);font-size:1rem;color:var(--ink);background:transparent;border:none;border-bottom:1px solid var(--rule);padding:.5rem 0;outline:none;transition:border-color .15s;width:100%}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-bottom-color:var(--ink)}.form-field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 0l5 6 5-6' fill='none' stroke='%237a7a7a' stroke-width='1.2'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 0 center;padding-right:1.2rem;cursor:pointer}.form-error{font-family:var(--font-ui);font-size:.82rem;color:var(--error);background:var(--error-bg);border:1px solid #e8c4c4;padding:.6rem .8rem;margin-bottom:.5rem}.step-heading{font-family:var(--font-body);font-size:1.4rem;font-weight:600;color:var(--ink);margin-bottom:.3rem}.step-subtext{font-family:var(--font-ui);font-size:.85rem;color:var(--ink-lighter);margin-bottom:1.5rem;line-height:1.5}.step-actions{display:flex;justify-content:space-between;align-items:center;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--rule)}.form-container{max-width:480px}.user-form{display:flex;flex-direction:column;gap:1rem}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.table-wrap{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-family:var(--font-ui);font-size:.82rem}.admin-table th{font-size:.65rem;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--ink-lighter);padding:.5rem .75rem;border-bottom:1px solid var(--rule-strong);text-align:left}.admin-table td{padding:.5rem .75rem;border-bottom:1px solid var(--rule);color:var(--ink);vertical-align:middle}.admin-table tr:hover{background:var(--bg-warm)}.row-disabled td{opacity:.5}.cell-mono{font-family:var(--font-mono);font-size:.78rem}.cell-actions{display:flex;gap:.35rem;flex-wrap:wrap}.text-faint{color:var(--ink-faint);font-style:italic}.role-badge{font-family:var(--font-ui);font-size:.62rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;padding:.12rem .4rem;display:inline-block}.role-badge--admin{color:var(--accent);border:1px solid var(--accent)}.role-badge--supervisor{color:var(--ink-light);border:1px solid var(--rule-strong)}.role-badge--submitter{color:var(--ink-faint);border:1px solid var(--rule)}.status-dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:.4rem;vertical-align:middle}.status-dot--active{background:var(--success)}.status-dot--inactive{background:var(--ink-faint)}.pw-badge{font-family:var(--font-ui);font-size:.58rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--ink-lighter);background:var(--sidebar-bg);padding:.1rem .3rem;margin-left:.3rem;vertical-align:middle}.dialog-backdrop{position:fixed;inset:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:100}.dialog-box{background:var(--bg);border:1px solid var(--rule-strong);padding:1.5rem;max-width:420px;width:90%}.dialog-title{font-family:var(--font-body);font-size:1.15rem;font-weight:600;margin-bottom:.5rem}.dialog-message{font-family:var(--font-ui);font-size:.85rem;color:var(--ink-light);line-height:1.5}.dialog-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1.25rem}.loading-spinner{width:28px;height:28px;border:2px solid var(--rule);border-top-color:var(--ink);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:700px){.masthead{padding:.75rem 1rem}.main-content{padding:1.25rem 1rem 2rem}.masthead-inner{flex-direction:column;align-items:flex-start;gap:.5rem}.masthead-right{align-self:flex-end}.admin-table{font-size:.75rem}.admin-table th,.admin-table td{padding:.35rem .5rem}.cell-actions{flex-direction:column}}
