:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;--bg: #f7f8fa;--surface: #ffffff;--surface-subtle: #f1f5f7;--line: #dbe3e7;--line-strong: #c9d5dc;--text: #131a22;--muted: #62717f;--muted-strong: #3f4c59;--teal: #057d7d;--teal-dark: #046263;--teal-soft: #e3f4f1;--green: #0f8f55;--green-soft: #e2f6eb;--amber: #a76606;--amber-soft: #fff2d8;--red: #c92f37;--red-soft: #fde7e8;--blue: #2467c9;--blue-soft: #e7f0ff;--shadow: 0 10px 28px rgba(29, 42, 56, .08);--radius: 8px}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;background:var(--bg);color:var(--text)}button,input,select{font:inherit}button{border:0;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}.app-shell{display:grid;grid-template-columns:252px minmax(0,1fr);min-height:100vh}.sidebar{display:flex;flex-direction:column;gap:24px;min-height:100vh;padding:22px 18px;background:#fbfcfd;border-right:1px solid var(--line)}.brand{display:flex;align-items:center;gap:12px;min-height:42px;font-size:22px}.brand-mark{display:grid;width:34px;height:34px;place-items:center;color:var(--teal)}.nav-list{display:grid;gap:6px}.nav-list button{display:flex;align-items:center;gap:12px;width:100%;min-height:42px;padding:0 12px;color:var(--muted-strong);background:transparent;border-left:3px solid transparent;border-radius:7px;text-align:left}.nav-list button.active,.nav-list button:hover{color:var(--teal-dark);background:var(--teal-soft);border-left-color:var(--teal)}.system-status{display:flex;align-items:center;gap:10px;margin-top:auto;padding:12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}.system-status strong,.system-status span{display:block}.system-status strong{font-size:13px}.system-status span{color:var(--muted);font-size:12px}.status-dot{width:10px;height:10px;border-radius:999px;background:var(--green)}.main-panel{min-width:0;padding:28px}.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:20px}.topbar h1{margin:0;font-size:24px;line-height:1.2}.topbar p{margin:6px 0 0;color:var(--muted);font-size:14px}.topbar-actions{display:flex;align-items:flex-start;gap:12px}.tenant-button,.secondary-button,.danger-button,.primary-button,.text-button,.icon-button,.filters button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:38px;border-radius:var(--radius);white-space:nowrap}.tenant-button,.secondary-button,.filters button{padding:0 13px;color:var(--muted-strong);background:var(--surface);border:1px solid var(--line)}.tenant-button{min-width:220px;justify-content:space-between}.primary-button{padding:0 14px;color:#fff;background:var(--teal)}.primary-button:hover{background:var(--teal-dark)}.danger-button{padding:0 14px;color:var(--red);background:var(--surface);border:1px solid #f0b9be}.text-button{padding:0 4px;color:var(--teal);background:transparent}.icon-button{width:38px;color:var(--muted-strong);background:transparent}.user-shell{display:grid;grid-template-columns:38px minmax(128px,1fr) 38px;align-items:center;gap:10px;min-width:278px}.user-shell strong,.user-shell span{display:block;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-shell strong{font-size:13px}.user-shell span{color:var(--muted);font-size:12px}.avatar{display:grid;width:38px;height:38px;place-items:center;color:#fff;background:linear-gradient(135deg,#247b9a,#2f8191);border-radius:999px;font-size:13px;font-weight:700}.auth-gate{display:grid;min-height:100vh;place-items:center;padding:32px 18px;background:linear-gradient(180deg,#fbfcfd,#eef4f5)}.auth-gate-panel{display:grid;width:min(100%,380px);gap:20px}.auth-gate-brand{justify-content:center}.auth-gate-copy{display:grid;gap:8px;text-align:center}.auth-gate-copy h1{margin:0;font-size:26px;line-height:1.2}.auth-gate-copy p{margin:0;color:var(--muted);font-size:14px;line-height:1.5}.auth-gate .auth-box{width:100%}.auth-box{width:320px;padding:12px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.auth-title{display:flex;align-items:center;gap:8px;margin-bottom:10px;color:var(--muted-strong);font-weight:700}.auth-box input{width:100%;height:38px;margin-bottom:8px;padding:0 10px;color:var(--text);background:#fff;border:1px solid var(--line);border-radius:7px}.auth-box p,.form-message{color:var(--muted);font-size:13px;line-height:1.45}.auth-actions{display:flex;justify-content:flex-end;gap:8px}.toast{display:flex;align-items:center;gap:10px;margin-bottom:16px;padding:12px 14px;border-radius:var(--radius);border:1px solid var(--line)}.toast button{margin-left:auto;color:inherit;background:transparent}.toast-success{color:#075c37;background:var(--green-soft);border-color:#b8e8ca}.toast-warning{color:#77500d;background:var(--amber-soft);border-color:#f3d084}.toast-error{color:#8a1f25;background:var(--red-soft);border-color:#efb5b9}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:22px}.metric-card{min-height:112px;padding:16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius)}.metric-label{display:flex;align-items:center;gap:9px;color:var(--muted-strong);font-size:13px}.metric-card strong{display:block;margin-top:14px;font-size:28px;line-height:1}.metric-detail{display:block;margin-top:8px;color:var(--muted);font-size:13px}.metric-success{color:var(--green)}.metric-danger{color:var(--red)}.content-grid{display:grid;grid-template-columns:minmax(720px,1fr) 390px;gap:18px;align-items:start}.work-area{display:grid;gap:20px;min-width:0}.table-section,.details-panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius)}.table-section{overflow:hidden}.section-heading{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 16px 12px}.section-heading h2,.details-panel h2,.details-panel h3{margin:0}.section-heading h2{font-size:18px}.data-table{display:grid;width:100%}.table-row{display:grid;align-items:center;min-width:0;min-height:58px;padding:0 12px;color:var(--muted-strong);background:#fff;border-top:1px solid var(--line);text-align:left}.connection-table .table-row{grid-template-columns:minmax(150px,1.2fr) 120px minmax(96px,.8fr) minmax(88px,.75fr) minmax(88px,.75fr) 96px 24px}.jobs-table .table-row{grid-template-columns:88px minmax(128px,1fr) minmax(132px,1fr) 120px 82px minmax(140px,1fr)}.invoice-status-table .table-row{grid-template-columns:minmax(140px,1fr) minmax(130px,1fr) 110px 120px 82px minmax(110px,.8fr)}.invoice-status-table small,.invoice-status-table strong{display:block}.invoice-status-table small{margin-top:3px;color:var(--muted);overflow-wrap:anywhere;font-size:12px}.source-link-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,330px);gap:16px;padding:0 16px 16px}.source-link-table{overflow:hidden;border:1px solid var(--line);border-radius:var(--radius)}.source-link-table .table-row{grid-template-columns:minmax(128px,.8fr) minmax(150px,1fr) minmax(120px,1fr) 78px 82px}.source-link-table small,.source-link-table strong{display:block}.source-link-table small{margin-top:3px;color:var(--muted);overflow-wrap:anywhere;font-size:12px}.source-app-pill{display:inline-flex;align-items:center;width:fit-content;min-height:24px;padding:4px 9px;color:var(--teal-dark);background:var(--teal-soft);border:1px solid #b9e2dc;border-radius:6px;font-size:12px;font-weight:700}.row-actions{display:inline-flex;justify-content:flex-end;gap:4px}.danger-icon{color:var(--red)}.source-link-form{display:grid;gap:10px;align-self:start;padding:14px;background:#fbfcfd;border:1px solid var(--line);border-radius:var(--radius)}.checkbox-row{display:flex;align-items:center;gap:9px;color:var(--muted-strong);font-size:13px;font-weight:700}.checkbox-row input{width:16px;height:16px;margin:0}.form-actions{display:flex;justify-content:flex-end;gap:8px}.table-head{min-height:38px;color:var(--muted);background:#fbfcfd;font-size:12px;font-weight:700}.empty-state{display:grid;gap:6px;color:var(--muted);font-size:13px;line-height:1.45}.empty-state strong{color:var(--text);font-size:14px}.table-empty{grid-column:1 / -1;min-height:96px;padding:22px 18px;align-content:center;border-top:1px solid var(--line);background:#fbfcfd}.details-empty{min-height:280px;align-content:center;padding:24px}.event-empty{padding:14px;border:1px dashed var(--line);border-radius:8px;background:#fbfcfd}button.table-row{width:100%}.connection-row.selected{background:#f1fbfb;box-shadow:inset 3px 0 0 var(--teal)}.provider-cell{display:inline-flex;align-items:center;gap:10px;min-width:0}.provider-cell strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.provider-mark{position:relative;display:inline-grid;width:28px;height:28px;flex:0 0 auto;place-items:center;border-radius:7px}.provider-mark:before,.provider-mark:after{position:absolute;content:"";border-radius:999px}.provider-mark:before{width:20px;height:20px;background:currentColor;opacity:.95}.provider-mark:after{width:8px;height:8px;background:#fff}.provider-poweroffice{color:#d82f55;background:#fde7ef}.provider-conta{color:#1d9a9b;background:#dff5f3}.provider-fiken{color:#2b4a9b;background:#e6edff}.provider-tripletex{color:#2d7d51;background:#e6f4ec}.status-pill{display:inline-flex;align-items:center;justify-content:center;gap:6px;width:fit-content;min-height:24px;padding:0 9px;border-radius:7px;font-size:12px;font-weight:700}.status-success{color:#08653c;background:var(--green-soft)}.status-warning{color:var(--amber);background:var(--amber-soft)}.status-danger{color:var(--red);background:var(--red-soft)}.env-pill{display:inline-flex;justify-content:center;width:fit-content;min-height:24px;padding:4px 9px;color:#195ab2;background:var(--blue-soft);border:1px solid #c6d9ff;border-radius:6px;font-size:12px;font-weight:700}.filters{display:flex;gap:10px;padding:0 16px 10px}.details-panel{position:sticky;top:18px;overflow:hidden}.details-header{display:flex;justify-content:space-between;gap:14px;padding:18px 18px 12px}.provider-title{display:flex;gap:12px}.provider-title .provider-mark{width:40px;height:40px}.details-panel h2{font-size:18px;line-height:1.2;margin-bottom:4px}.tabs{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));border-bottom:1px solid var(--line)}.tabs button{min-height:42px;color:var(--muted);background:transparent;border-bottom:2px solid transparent;font-size:13px}.tabs button.active{color:var(--teal-dark);border-bottom-color:var(--teal)}.connect-section{display:grid;gap:12px;padding:18px;border-bottom:1px solid var(--line);background:#fbfcfd}.connect-heading{display:flex;align-items:center;justify-content:space-between;gap:10px}.connect-heading h3{margin:0;font-size:14px}.setup-badge{display:inline-flex;align-items:center;min-height:22px;padding:0 8px;color:var(--teal-dark);background:var(--teal-soft);border-radius:6px;font-size:12px;font-weight:700}.provider-setup{display:grid;gap:10px}.field-row{display:grid;gap:6px;color:var(--muted-strong);font-size:13px;font-weight:700}.field-row input,.field-row select{width:100%;min-height:38px;padding:0 10px;color:var(--text);background:var(--surface);border:1px solid var(--line);border-radius:7px}.inline-warning{display:grid;gap:4px;padding:10px 12px;color:#77500d;background:var(--amber-soft);border:1px solid #f3d084;border-radius:7px;font-size:12px}.inline-warning span{overflow-wrap:anywhere}.setup-link{display:inline-flex;align-items:center;min-height:38px;color:var(--teal-dark);font-size:13px;font-weight:700}.details-section,.capacity-section{padding:18px;border-bottom:1px solid var(--line)}.details-section h3,.capacity-section h3{margin-bottom:14px;font-size:14px}dl{display:grid;gap:13px;margin:0}dl div{display:grid;grid-template-columns:minmax(110px,1fr) minmax(0,1.3fr);gap:12px}dt{color:var(--muted);font-size:13px}dd{min-width:0;margin:0;overflow-wrap:anywhere;color:var(--muted-strong);font-size:13px;text-align:right}.capability-value{display:inline-flex;align-items:center;justify-content:flex-end;gap:8px}.toggle{display:inline-flex;width:34px;height:20px;padding:3px;border-radius:999px;background:#cbd5dc}.toggle:before{width:14px;height:14px;content:"";border-radius:999px;background:#fff;transition:transform .16s ease}.toggle.on{background:var(--green)}.toggle.on:before{transform:translate(14px)}.progress-row{display:grid;gap:8px;margin-bottom:13px}.progress-row div{display:flex;justify-content:space-between;color:var(--muted-strong);font-size:13px}.progress-track{display:block;height:7px;overflow:hidden;background:#e4e9ed;border-radius:999px}.progress-track span{display:block;height:100%;background:var(--teal);border-radius:inherit}.event-list{display:grid;gap:10px}.event-item{display:flex;gap:9px;color:var(--muted-strong)}.event-item strong,.event-item span{display:block;font-size:12px}.event-item span{color:var(--muted);margin-top:2px}.action-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:18px}.wide{grid-column:1 / -1}.ok-text{color:var(--green);font-weight:700}.danger-text{color:var(--red)}.muted-text{color:var(--muted)}.setup-shell{display:grid;min-height:100vh;place-items:center;padding:32px 18px;background:#eef4f5}.setup-panel{display:grid;width:min(100%,620px);gap:20px;padding:22px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.setup-panel-narrow{width:min(100%,420px)}.setup-header{display:flex;align-items:center;justify-content:space-between;gap:14px}.setup-brand{font-size:20px}.setup-title{display:grid;gap:6px}.setup-title h1{margin:0;font-size:26px;line-height:1.2}.setup-title p{margin:0;color:var(--muted)}.setup-state,.setup-error{display:flex;align-items:center;gap:12px;color:var(--muted-strong)}.setup-error{align-items:flex-start;color:var(--red)}.setup-error h1,.setup-error p{margin:0}.setup-error h1{color:var(--text);font-size:22px;line-height:1.2}.setup-error p{margin-top:6px;color:var(--muted);line-height:1.45}.setup-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.setup-summary div{display:grid;gap:4px;min-height:86px;padding:12px;background:#fbfcfd;border:1px solid var(--line);border-radius:var(--radius)}.setup-summary span,.setup-summary small{color:var(--muted);font-size:12px}.setup-summary strong{overflow-wrap:anywhere}.setup-form{display:grid;gap:12px}.setup-return-link{width:fit-content;text-decoration:none}@media(max-width:1420px){.content-grid{grid-template-columns:1fr}.details-panel{position:static}.source-link-layout{grid-template-columns:1fr}}@media(max-width:960px){.app-shell{grid-template-columns:1fr}.sidebar{min-height:auto;border-right:0;border-bottom:1px solid var(--line)}.nav-list{grid-template-columns:repeat(5,minmax(0,1fr))}.nav-list button{justify-content:center;padding:0 8px}.nav-list span,.system-status{display:none}.topbar,.topbar-actions{flex-direction:column;width:100%}.tenant-button,.auth-box,.user-shell{width:100%;min-width:0}.metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.main-panel{padding:18px}.connection-table,.jobs-table,.invoice-status-table,.source-link-table{overflow-x:auto}.connection-table .table-row{min-width:860px}.jobs-table .table-row,.invoice-status-table .table-row{min-width:760px}.source-link-table .table-row{min-width:720px}.metrics-grid,.setup-summary{grid-template-columns:1fr}.filters{overflow-x:auto}}
