@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap");*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1117;--ink:#161b27;--card:#1a1f2e;--line:#2a3050;--line-2:#1e2438;--fg:#c8cfe8;--muted:#6b7aaa;--orange:#f15a22;--blue:#2d6cdf;--green:#198f4b;--red:#c0392b;--amber:#c9820a;--violet:#6b43c9;--mono:"JetBrains Mono",monospace;--disp:"Inter",sans-serif}body{background:var(--bg);color:var(--fg);font-family:var(--disp);font-size:14px;line-height:1.5;min-height:100dvh}.fsp-root{display:flex;height:100dvh;overflow:hidden}.fsp-side{width:220px;min-width:220px;background:var(--ink);border-right:1px solid var(--line);display:flex;flex-direction:column;overflow-y:auto}.fsp-main{flex:1 1;display:flex;flex-direction:column;overflow:hidden}.fsp-top{display:flex;align-items:center;gap:12px;padding:14px 24px;border-bottom:1px solid var(--line);background:var(--ink);flex-shrink:0;flex-wrap:wrap}.fsp-top-t{font-size:17px;font-weight:700;color:#fff}.fsp-top-s{font-size:12px;color:var(--muted);margin-top:1px}.fsp-top-spacer{flex:1 1}.fsp-content{flex:1 1;overflow-y:auto;padding:24px}.fsp-brand{gap:10px;padding:18px 16px 14px;border-bottom:1px solid var(--line)}.fsp-brand,.fsp-logo{display:flex;align-items:center}.fsp-logo{width:36px;height:36px;background:var(--orange);border-radius:9px;justify-content:center;flex-shrink:0}.fsp-logo svg{width:20px;height:20px}.fsp-brand-t{font-weight:700;font-size:14px;color:#fff}.fsp-brand-s{font-size:11px;color:var(--muted)}.fsp-nav{padding:10px 8px;flex:1 1}.fsp-nav-h{font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);padding:10px 8px 4px}.fsp-navbtn{display:flex;align-items:center;gap:9px;width:100%;padding:8px 10px;border:none;background:none;color:var(--muted);border-radius:8px;cursor:pointer;font-size:13.5px;font-family:var(--disp);position:relative;transition:background .15s,color .15s}.fsp-navbtn svg{width:16px;height:16px;flex-shrink:0}.fsp-navbtn:hover{background:var(--card);color:var(--fg)}.fsp-navbtn.on{background:var(--card);color:#fff;font-weight:600}.fsp-badge-n{color:#fff;border-radius:10px;font-size:11px;font-weight:700;padding:1px 7px}.fsp-badge-n,.fsp-nb-ac{margin-left:auto;background:var(--orange)}.fsp-nb-ac{width:6px;height:6px;border-radius:50%}.fsp-side-foot{padding:14px 16px;border-top:1px solid var(--line)}.fsp-qb{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--muted)}.fsp-qb-dot{width:7px;height:7px;border-radius:50%;background:var(--green);flex-shrink:0}.fsp-search{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);border-radius:9px;padding:7px 12px;min-width:200px}.fsp-search svg{width:15px;height:15px;color:var(--muted);flex-shrink:0}.fsp-search input{background:none;border:none;outline:none;color:var(--fg);font-size:13px;width:100%;font-family:var(--disp)}.fsp-search input::placeholder{color:var(--muted)}.fsp-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;border:none;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--disp);transition:opacity .15s;white-space:nowrap}.fsp-btn svg{width:15px;height:15px}.fsp-btn-pri{background:var(--orange);color:#fff}.fsp-btn-blue{background:var(--blue);color:#fff}.fsp-btn-gho{background:var(--card);color:var(--fg);border:1px solid var(--line)}.fsp-btn-sm{padding:5px 11px;font-size:12px}.fsp-btn:hover{opacity:.85}.fsp-x{background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;border-radius:6px;display:flex}.fsp-x svg{width:18px;height:18px}.fsp-back{display:inline-flex;align-items:center;gap:6px;background:none;border:none;color:var(--muted);cursor:pointer;font-size:13px;font-family:var(--disp);padding:0;margin-bottom:16px}.fsp-back svg{width:16px;height:16px}.fsp-back:hover{color:var(--fg)}.fsp-kpis{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:16px;gap:16px;margin-bottom:24px}.fsp-kpi{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px;position:relative;overflow:hidden}.fsp-kpi-bar{position:absolute;top:0;left:0;right:0;height:3px}.fsp-kpi-lab{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.4px;margin-bottom:10px}.fsp-kpi-lab svg{width:14px;height:14px}.fsp-kpi-v{font-size:32px;font-weight:700;color:#fff;line-height:1}.fsp-kpi-sub{font-size:12px;color:var(--muted);margin-top:6px}.fsp-panel{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden}.fsp-panel-h{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line)}.fsp-panel-t{font-weight:700;font-size:14px;color:#fff}.fsp-panel-link{background:none;border:none;color:var(--blue);font-size:12px;cursor:pointer;font-family:var(--disp)}.fsp-grid2{display:grid;grid-template-columns:1fr 1fr;grid-gap:20px;gap:20px}.fsp-job{display:flex;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid var(--line-2);cursor:default}.fsp-job:last-child{border-bottom:none}.fsp-job:hover{background:hsla(0,0%,100%,.02)}.fsp-job-time{font-size:12px;font-family:var(--mono);color:var(--muted);width:42px;flex-shrink:0}.fsp-job-pipe{width:3px;height:36px;border-radius:2px;flex-shrink:0}.fsp-job-main{flex:1 1;min-width:0}.fsp-job-t{font-weight:600;font-size:13.5px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fsp-job-m{font-size:12px;color:var(--muted);margin-top:2px}.fsp-table{width:100%;border-collapse:collapse;font-size:13px}.fsp-table th{text-align:left;padding:10px 16px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);border-bottom:1px solid var(--line)}.fsp-table td{padding:12px 16px;border-bottom:1px solid var(--line-2);vertical-align:middle}.fsp-table tr:last-child td{border-bottom:none}.fsp-table tr:hover td{background:hsla(0,0%,100%,.02)}.fsp-table tr{cursor:pointer}.fsp-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:11.5px;font-weight:600;white-space:nowrap}.fsp-chip .d{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.c-new{background:#1e2438;color:#8892b0}.c-scheduled{background:#1a2a3a;color:#60a5fa}.c-progress{background:#2a1f10;color:#f59e0b}.c-parts{background:#1e1030;color:#a78bfa}.c-completed{background:#0f2a1a;color:#4ade80}.c-invoiced{background:#1a1030;color:#c084fc}.c-paid{background:#0f2a1a;color:#4ade80}.c-overdue{background:#2a1010;color:#f87171}.c-sent{background:#1a2a3a;color:#60a5fa}.c-draft{background:#1e2438;color:#8892b0}.c-pending{background:#2a200a;color:#fbbf24}.fsp-ticket{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden}.fsp-ticket-h{background:#0d1120;padding:20px 24px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;border-bottom:1px solid var(--line)}.fsp-ticket-no{font-family:var(--mono);font-size:12px;color:var(--muted);margin-bottom:6px}.fsp-ticket-title{font-size:22px;font-weight:700;color:#fff;line-height:1.2}.fsp-ticket-body{padding:22px 24px}.fsp-deftbl{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px 24px;gap:16px 24px;margin-bottom:20px}.fsp-def-l{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:4px}.fsp-def-v{font-size:14px;color:var(--fg)}.fsp-line-h{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin:20px 0 10px}.fsp-board{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));grid-gap:16px;gap:16px}.fsp-tech-col{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden}.fsp-tech-head{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--line);background:#0d1120}.fsp-tech-name{font-weight:700;font-size:14px;color:#fff}.fsp-tech-meta{font-size:12px;color:var(--muted);margin-top:1px}.fsp-tech-slots{padding:10px 12px;display:flex;flex-direction:column;gap:8px}.fsp-slot{background:var(--ink);border:1px solid var(--line);border-left:3px solid var(--blue);border-radius:8px;padding:10px 12px;cursor:pointer}.fsp-slot:hover{background:#1e2438}.fsp-slot-t{font-weight:600;font-size:13px;color:#fff}.fsp-slot-time{display:flex;align-items:center;gap:4px;font-size:11.5px;color:var(--muted);margin-top:4px}.fsp-slot-time svg{width:12px;height:12px}.fsp-empty-col{padding:20px;text-align:center;color:var(--muted);font-size:13px}.fsp-avi{width:36px;height:36px;border-radius:10px;justify-content:center;font-weight:700;font-size:13px;color:#fff;flex-shrink:0}.fsp-avi,.fsp-cellflex{display:flex;align-items:center}.fsp-cellflex{gap:10px}.fsp-id{font-family:var(--mono);font-size:12px;color:var(--muted);font-weight:500}.fsp-money,.fsp-strong{font-weight:600;color:#fff}.fsp-money{font-family:var(--mono)}.fsp-tag{border:1px solid var(--line);border-radius:5px;padding:2px 7px;font-family:var(--mono);font-size:11.5px}.fsp-note,.fsp-tag{background:var(--ink);color:var(--muted)}.fsp-note{border:1px solid var(--line);border-radius:10px;padding:14px 16px;font-size:13px;line-height:1.6}.fsp-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:#1a2a3a;border:1px solid var(--blue);border-radius:10px;padding:12px 20px;color:#fff;font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px;z-index:100;box-shadow:0 8px 32px rgba(0,0,0,.4)}.fsp-toast svg{width:16px;height:16px;color:var(--green)}.fsp-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:50;padding:20px}.fsp-modal{background:var(--card);border:1px solid var(--line);border-radius:16px;width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column}.fsp-modal-h{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--line)}.fsp-modal-t{font-weight:700;font-size:16px;color:#fff}.fsp-modal-b{padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:14px}.fsp-modal-f{padding:16px 20px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:10px}.fsp-field{display:flex;flex-direction:column;gap:6px}.fsp-field.row{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.fsp-lab{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}.fsp-inp{background:var(--ink);border:1px solid var(--line);border-radius:8px;padding:9px 12px;color:var(--fg);font-size:14px;font-family:var(--disp);outline:none;width:100%}.fsp-inp:focus{border-color:var(--blue)}.fsp-sel{background:var(--ink);border:1px solid var(--line);border-radius:8px;padding:9px 12px;color:var(--fg);font-size:14px;font-family:var(--disp);outline:none;width:100%}.fsp-sel:focus{border-color:var(--blue)}.fsp-ta{background:var(--ink);border:1px solid var(--line);border-radius:8px;padding:9px 12px;color:var(--fg);font-size:14px;font-family:var(--disp);outline:none;width:100%;resize:vertical;min-height:80px}.fsp-ta:focus{border-color:var(--blue)}.fsp-qbcard{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px 24px;gap:16px;margin-bottom:20px}.fsp-qb-logo,.fsp-qbcard{display:flex;align-items:center}.fsp-qb-logo{width:44px;height:44px;background:#2ca01c;border-radius:10px;justify-content:center;font-weight:900;font-size:14px;color:#fff;flex-shrink:0}