*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:#f6f7fb;color:#111}
a{color:inherit}
.topbar{display:flex;gap:16px;justify-content:space-between;align-items:flex-end;padding:18px;background:#fff;border-bottom:1px solid #e7e7ee}
.topbar h1{margin:0;font-size:20px}
.topbar p{margin:6px 0 0;color:#555}
.layout{display:grid;grid-template-columns:1.6fr 1fr;gap:16px;padding:16px}
.layout--single{grid-template-columns:1fr;max-width:980px;margin:0 auto}
.card{background:#fff;border:1px solid #e7e7ee;border-radius:12px;padding:12px;box-shadow:0 2px 10px rgba(0,0,0,.04)}
.field{display:grid;gap:6px;font-size:13px;color:#333}
.field span{color:#444}
.field input,.field select,.field textarea{width:100%;padding:10px;border-radius:10px;border:1px solid #d9d9e2;outline:none;background:#fff}
.field textarea{min-height:70px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{border-color:#8aa2ff}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.grid--3{grid-template-columns:1fr 1fr 1fr}
.grid .span-2{grid-column:1/-1}
.btn{margin-top:12px;width:100%;padding:12px;border:0;border-radius:10px;background:#2f5cff;color:#fff;font-weight:650;cursor:pointer}
.btn--ghost{background:#fff;color:#2f5cff;border:1px solid #cfd6ff}
.btn--danger{background:#b00020}
.btn--small{padding:8px 10px;border-radius:10px;width:auto;margin:0}
.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.status{margin-top:10px;min-height:18px;font-size:13px}
.hint{margin-top:10px;font-size:13px;color:#444}
.note{margin-top:14px;font-size:13px;color:#444}
.table{width:100%;border-collapse:collapse;font-size:13px}
.table th,.table td{padding:10px;border-bottom:1px solid #eee;text-align:left;vertical-align:top}
.badge{display:inline-block;padding:2px 8px;border-radius:999px;background:#eef2ff;color:#2f5cff;font-size:12px;font-weight:650}
.badge--block{background:#ffe8e8;color:#b00020}
hr{border:0;border-top:1px solid #eee;margin:12px 0}
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.35);display:none;align-items:center;justify-content:center;padding:16px}
.modal{width:min(680px,100%);background:#fff;border-radius:14px;border:1px solid #e7e7ee;box-shadow:0 20px 70px rgba(0,0,0,.25);padding:14px}
.modal h3{margin:0 0 10px;font-size:16px}
.modal .actions{display:flex;gap:10px;justify-content:flex-end;margin-top:12px}
@media (max-width:980px){.layout{grid-template-columns:1fr}}

/* Modal used in admin dashboard */
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.35);padding:16px;z-index:50}
.modal.open{display:flex}
.modal__card{width:min(760px,100%);background:#fff;border-radius:14px;border:1px solid #e7e7ee;box-shadow:0 20px 70px rgba(0,0,0,.25);padding:14px}
.modal__header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px}
.modal__header h2{margin:0;font-size:16px}

.actions{display:flex;gap:10px;flex-wrap:wrap}
.btn--outline{background:#fff;color:#2f5cff;border:1px solid #cfd6ff}
.btn{width:auto;margin:0}
.card--form .btn{width:100%;margin-top:12px}
.row--space{justify-content:space-between}
.muted{color:#666}
.pill{display:inline-block;padding:2px 8px;border-radius:999px;background:#eef2ff;color:#2f5cff;font-size:12px;font-weight:650}
.pill.block{background:#ffe8e8;color:#b00020}
.tableWrap{overflow:auto}
.quote{margin-top:10px;padding:10px;border:1px dashed #d9d9e2;border-radius:10px;font-size:13px}
.quote .total{margin-top:6px;font-size:14px}
.pill{display:inline-block;padding:2px 8px;border-radius:999px;background:#eef2ff;color:#2f5cff;font-size:12px;font-weight:650}
.pill.block{background:#ffe8e8;color:#b00020}
.muted{color:#666}
.tableWrap{overflow:auto}
.actions{display:flex;gap:12px;flex-wrap:wrap}
.btn--outline{background:#fff;color:#111;border:1px solid #ddd}
.btn--danger.btn--small{border:0}
.btn--ghost.btn--small{width:auto}
.row--space{justify-content:space-between;width:100%}
.quote{margin-top:10px;padding:10px;border:1px dashed #d9d9e2;border-radius:10px;font-size:13px;color:#333}
.quote .total{margin-top:6px;font-size:14px}
.quote{margin-top:12px;padding:10px;border:1px dashed #d9d9e2;border-radius:12px;font-size:13px;color:#333}
.quote .total{margin-top:6px;font-size:14px}
