:root{--bg:#f5f7fb;--surface:#fff;--border:#e3e8ef;--primary:#0d6efd;--primary-dark:#0b5ed7;--text:#1a2433;--muted:#687385;--warning:#fff8c5;--danger:#dc3545;--success:#198754;--radius:8px;--shadow:0 1px 3px #0f172a0d, 0 4px 12px #0f172a0a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,Roboto,Helvetica Neue,Arial,sans-serif}*{box-sizing:border-box}html,body,#root{background:var(--bg);height:100%;color:var(--text);margin:0;padding:0;font-size:14px}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}button{font:inherit;cursor:pointer}.btn{border-radius:var(--radius);background:var(--primary);color:#fff;border:1px solid #0000;justify-content:center;align-items:center;padding:8px 16px;font-weight:500;transition:background .15s;display:inline-flex}.btn:hover:not(:disabled){background:var(--primary-dark)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn--ghost{color:var(--text);border-color:var(--border);background:0 0}.btn--ghost:hover:not(:disabled){background:#eef1f6}.btn--danger{background:var(--danger)}.btn--danger:hover:not(:disabled){background:#b02a37}.btn--small{padding:4px 10px;font-size:12px}input,select,textarea{font:inherit;border:1px solid var(--border);width:100%;color:var(--text);background:#fff;border-radius:6px;padding:7px 10px}input:focus,select:focus,textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #0d6efd26}label{color:var(--text);margin-bottom:4px;font-weight:500;display:block}.field{margin-bottom:14px}.field__hint{color:var(--muted);margin-top:2px;font-size:12px}.card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:10px;padding:18px}.alert{border-radius:var(--radius);border:1px solid var(--border);margin-bottom:12px;padding:10px 14px}.alert--error{color:#b02a37;background:#ffeef0;border-color:#ffd1d6}.alert--info{color:#084298;background:#e7f3ff;border-color:#b6daff}.login-page{background:linear-gradient(135deg,#0d6efd 0%,#4ba7ff 100%);place-items:center;min-height:100vh;padding:16px;display:grid}.login-card{background:#fff;border-radius:14px;width:100%;max-width:380px;padding:32px;box-shadow:0 10px 40px #0f172a26}.login-card h1{color:var(--text);margin:0 0 4px;font-size:22px}.login-card .subtitle{color:var(--muted);margin-bottom:24px;font-size:13px}.login-card .demo{color:var(--muted);background:#f5f7fb;border-radius:6px;margin-top:18px;padding:10px;font-size:12px}.app{flex-direction:column;min-height:100vh;display:flex}.topbar{color:#f0f4fa;z-index:50;background:#1a2433;align-items:center;gap:24px;height:56px;padding:0 24px;display:flex;position:sticky;top:0;box-shadow:0 2px 8px #0f172a14}.topbar__brand{flex-shrink:0;align-items:baseline;gap:8px;display:flex}.topbar__logo{font-size:20px}.topbar__title{letter-spacing:.3px;color:#fff;font-size:18px;font-weight:700}.topbar__tag{color:#8aa1c2;font-size:11px;font-weight:400}.topbar__nav{flex:1;gap:2px;display:flex}.topbar__link{color:#cdd9ea;white-space:nowrap;border-radius:6px;align-items:center;padding:7px 14px;font-size:13px;font-weight:500;display:inline-flex}.topbar__link:hover{color:#fff;background:#29384e;text-decoration:none}.topbar__link--active{background:var(--primary);color:#fff}.topbar__user{flex-shrink:0;align-items:center;gap:10px;display:flex}.topbar__user-info{flex-direction:column;align-items:flex-end;line-height:1.25;display:flex}.topbar__user-info b{color:#fff;font-size:12px}.topbar__user-info .role{background:var(--primary);color:#fff;text-transform:uppercase;letter-spacing:.3px;border-radius:999px;margin-top:2px;padding:1px 7px;font-size:10px}.topbar__user-info .role--manager{background:#ad6a00}.topbar__logout{color:#cdd9ea;background:0 0;border:1px solid #29384e;border-radius:6px;padding:6px 11px;font-size:12px}.topbar__logout:hover{color:#fff;background:#29384e}.main{width:100%;max-width:1600px;margin:0 auto;padding:22px 32px 40px;overflow-y:auto}@media (width<=768px){.topbar{flex-wrap:wrap;gap:8px;height:auto;padding:8px 14px}.topbar__tag{display:none}.topbar__nav{order:3;width:100%;overflow-x:auto}.main{padding:16px}}.page-header{justify-content:space-between;align-items:flex-end;margin-bottom:18px;display:flex}.page-header h1{margin:0 0 2px;font-size:22px}.page-header .subtitle{color:var(--muted);font-size:13px}.table{border-collapse:collapse;background:var(--surface);width:100%;box-shadow:var(--shadow);border-radius:10px;overflow:hidden}.table th,.table td{text-align:left;border-bottom:1px solid var(--border);padding:12px 14px}.table th{text-transform:uppercase;color:var(--muted);letter-spacing:.4px;background:#f9fbfd;font-size:12px;font-weight:600}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:#f8fafc}.badge{color:#084298;background:#e7f3ff;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.calc-grid{grid-template-columns:minmax(380px,1fr) minmax(420px,1.2fr);align-items:flex-start;gap:24px;display:grid}.calc-grid__col{flex-direction:column;gap:18px;display:flex}.section{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:10px;overflow:hidden}.section__head{border-bottom:1px solid var(--border);background:#f7f9fc;justify-content:space-between;align-items:center;padding:11px 16px;font-size:13px;font-weight:600;display:flex}.section__body{grid-template-columns:1fr 1fr;gap:14px;padding:14px 16px;display:grid}.section__body .field{margin-bottom:0}.section__body .field--full{grid-column:1/-1}.input-with-unit{position:relative}.input-with-unit .unit{color:var(--muted);pointer-events:none;background:#fff;padding:0 4px;font-size:12px;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.calc-actions{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:10px;flex-wrap:wrap;align-items:center;gap:8px;padding:14px 16px;display:flex}.quote-sheet{border:1px solid var(--border);box-shadow:var(--shadow);background:#fff;border-radius:10px;padding:22px;font-size:13px}.quote-sheet__title{text-align:center;margin:8px 0 18px;font-size:18px;font-weight:700}.quote-sheet__row{border-bottom:1px solid #f0f3f7;grid-template-columns:24px 1.2fr .8fr 60px 50px 90px 110px;align-items:center;gap:4px;padding:4px 0;display:grid}.quote-sheet__row--head{border-bottom:2px solid var(--border);text-transform:uppercase;color:var(--muted);background:#f7f9fc;padding:7px 0;font-size:11px;font-weight:600}.quote-sheet__row--total{background:#fff8c5;border-bottom:2px solid #d4a017;font-weight:700}.quote-sheet__row--bold{font-weight:600}.quote-sheet__hide{color:var(--muted);font-style:italic}.empty-state{text-align:center;color:var(--muted);padding:60px 20px}.empty-state h2{color:var(--text);margin:12px 0 6px}@media print{.topbar,.calc-actions,.no-print{display:none!important}.main{padding:0}.quote-sheet{box-shadow:none;border:none}}.modal-backdrop{z-index:100;background:#0f172a66;place-items:center;display:grid;position:fixed;inset:0}.modal{background:#fff;border-radius:12px;width:100%;max-width:480px;padding:24px;box-shadow:0 24px 60px #0000002e}.modal h2{margin:0 0 16px;font-size:18px}.modal__actions{justify-content:flex-end;gap:8px;margin-top:18px;display:flex}
