*{box-sizing:border-box}
html,body{height:100%}
body{font-family:Assistant,sans-serif;margin:0;padding:16px;background:#1a1d24;color:#e8eaed;overflow:auto;min-height:100vh}
h1{font-size:18px;margin:0 0 12px;color:#fff}
.toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;gap:12px;flex-wrap:wrap}
.search-box{position:relative;flex:1;max-width:280px}
.search-box input{width:100%;padding:10px 14px 10px 36px;border:1px solid #3a3f4b;border-radius:999px;background:#2a2e38;color:#e8eaed;font-size:14px;font-family:inherit}
.table-wrap{overflow:auto;max-height:62vh;border-radius:8px;background:#1f232b;box-shadow:0 1px 3px rgba(0,0,0,.3)}
table{width:auto;border-collapse:collapse;min-width:1100px;max-width:100%;table-layout:fixed}
th,td{overflow:hidden;text-overflow:ellipsis}
th{background:#1f232b;color:#9ba0ab;padding:14px 10px;font-size:13px;text-align:right;font-weight:500;border-bottom:1px solid #2d323d;white-space:nowrap;position:sticky;top:0;z-index:5}
.pager{display:flex;justify-content:center;align-items:center;gap:10px;margin-top:12px;font-size:13px;color:#9ba0ab}
.pager button{background:#2a2e38;border:1px solid #3a3f4b;color:#e8eaed;border-radius:6px;padding:6px 12px;cursor:pointer}
.pager button:disabled{opacity:.4;cursor:default}
th .req{color:#10b981;margin-right:2px}
td{padding:8px 10px;border-bottom:1px solid #2a2e38;font-size:14px;vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:#252932}
input[type=number],input[type=text],input[type=date],input[type=email],select,textarea{width:100%;padding:8px 12px;border:1px solid #3a3f4b;border-radius:6px;font-size:14px;font-family:inherit;background:#2a2e38;color:#e8eaed}
input.invalid,select.invalid{border-color:#ef4444;background:#2a1f24}
.readonly{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#252932;border:1px solid #2d323d;border-radius:6px;color:#9ba0ab}
.autocomplete{position:relative}
.autocomplete-list{position:fixed;background:#2a2e38;border:1px solid #3a3f4b;border-radius:6px;max-height:240px;overflow-y:auto;z-index:2000;display:none;box-shadow:0 8px 24px rgba(0,0,0,.4);min-width:200px}
.autocomplete-list.show{display:block}
.autocomplete-item{padding:8px 12px;cursor:pointer;font-size:13px;color:#e8eaed}
.autocomplete-item:hover,.autocomplete-item.active{background:#3a3f4b}
.autocomplete-item.ac-create{position:sticky;top:0;background:#1f232b;color:#10b981;font-weight:600;border-bottom:1px solid #2d323d}
.autocomplete-item.ac-create:hover{background:#10b981;color:#fff}
.btn{padding:8px 18px;border:none;border-radius:999px;cursor:pointer;font-family:inherit;font-size:14px;font-weight:500}
.btn-add{background:#10b981;color:#fff}.btn-add:hover{background:#0ea571}
.btn-save{background:transparent;border:1px solid #3a3f4b;color:#9ba0ab;padding:6px 14px;font-size:13px;border-radius:8px}
.btn-save.dirty{background:#10b981;border-color:#10b981;color:#fff;font-weight:600}
.btn-del{background:transparent;border:1px solid transparent;color:#6b7280;padding:5px;font-size:15px;width:28px;height:28px;border-radius:8px;opacity:.55}
.btn-del:hover{background:#3a1f1f;color:#ef4444;opacity:1}
.row-actions{display:flex;gap:10px;align-items:center}
.ac-disabled{opacity:.5;cursor:not-allowed;font-style:italic}
.summary{background:#1f232b;padding:14px;border-radius:8px;margin-top:14px}
.summary-row{display:flex;justify-content:space-between;margin:4px 0}
.summary-row.total{font-size:16px;font-weight:700;border-top:1px solid #2d323d;padding-top:8px;margin-top:8px}
.pending{opacity:.5}
.saved-flash td{background:#10341f !important;transition:background .8s}
.err{color:#ef9a9a;font-size:12px;margin-top:8px;min-height:16px}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:none;align-items:flex-start;justify-content:center;z-index:5000;overflow-y:auto;padding:30px 16px}
.modal-overlay.show{display:flex}
.modal{background:#1f232b;border:1px solid #3a3f4b;border-radius:12px;width:100%;max-width:560px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #2d323d}
.modal-head h2{margin:0;font-size:17px;color:#fff}
.modal-head .x{cursor:pointer;font-size:22px;color:#9ba0ab;background:none;border:none}
.modal-body{padding:18px 20px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
@media (max-width:820px){ .modal-body{grid-template-columns:1fr 1fr} }
@media (max-width:520px){ .modal-body{grid-template-columns:1fr} }
.modal-field{display:flex;flex-direction:column;gap:4px}
.modal-field.full{grid-column:1/-1}
.modal-section{grid-column:1/-1;font-size:12px;font-weight:700;color:#7dd3a8;border-bottom:1px solid #2d323d;padding-bottom:5px;margin-top:8px}
.modal-field label{font-size:12px;color:#9ba0ab}
.modal-field label .req{color:#10b981}
.modal-foot{padding:14px 20px;border-top:1px solid #2d323d;display:flex;justify-content:flex-end;gap:10px}
.modal-note{grid-column:1/-1;font-size:11px;color:#6b7280}
#boot-loading{display:flex;align-items:center;justify-content:center;min-height:300px;flex-direction:column;gap:14px;color:#9ba0ab}
#boot-loading .spinner{width:36px;height:36px;border:3px solid #2d323d;border-top-color:#10b981;border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
#boot-error{display:none;padding:30px;text-align:center;color:#ef9a9a}
#boot-error code{display:block;background:#2a1f24;padding:10px;border-radius:6px;margin-top:10px;font-size:11px;text-align:left;direction:ltr;white-space:pre-wrap;word-break:break-all}
