@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap";:root{color-scheme:light;--bg: #e7edf3;--bg-secondary: #f4f7fa;--panel: #ffffff;--panel-border: #b6c2cf;--panel-shadow: rgba(15, 23, 42, .12);--primary: #237a57;--primary-dark: #16573f;--accent: #e6c34e;--text: #1a2b3c;--muted: #5c6b7a;--sidebar: #d6dde6;--sidebar-dark: #c4ccd8;--table-header: #d9e3ee;--table-row: #f7f9fb;--danger: #b3261e;--success: #2e7d32;--warning: #b26a00}:root[data-theme=midnight]{color-scheme:dark;--bg: #0f172a;--bg-secondary: #121c2b;--panel: #101c2a;--panel-border: #2b3a52;--panel-shadow: rgba(0, 0, 0, .45);--primary: #4fbf8a;--primary-dark: #329065;--accent: #f1c453;--text: #eef2f7;--muted: #a8b3bf;--sidebar: #162336;--sidebar-dark: #131f30;--table-header: #1f2c40;--table-row: #131e2c;--danger: #ef4444;--success: #34d399;--warning: #f59e0b}:root[data-theme=midnight] body{background:linear-gradient(135deg,#0a1220,#101a2c 60%,#0f172a)}*{box-sizing:border-box}body{margin:0;font-family:IBM Plex Sans,Segoe UI,sans-serif;color:var(--text);background:linear-gradient(135deg,#dde6ef,#f6f9fc 55%,#e8eff7);min-height:100vh}#root{min-height:100vh}a{color:inherit;text-decoration:none}.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{position:relative;z-index:20;background:linear-gradient(180deg,var(--sidebar) 0%,var(--sidebar-dark) 100%);border-right:2px solid var(--panel-border);padding:24px 18px;display:flex;flex-direction:column;gap:24px;overflow:visible}.brand{display:flex;gap:12px;align-items:center}.brand-mark{background:radial-gradient(circle at top,#3da47d,#1d5a40 85%);color:#fff;font-weight:700;width:42px;height:42px;border-radius:8px;display:grid;place-items:center;box-shadow:inset 0 0 0 2px #ffffff59}.brand-title{font-weight:700;font-size:1.1rem}.brand-subtitle{font-size:.78rem;color:var(--muted)}.sidebar-nav{display:flex;flex-direction:column;gap:8px}.sidebar-section{position:relative}.sidebar-section-button{width:100%;padding:10px 14px;border-radius:8px;border:1px solid transparent;display:flex;align-items:center;justify-content:space-between;background:transparent;color:#243244;font-weight:600;cursor:pointer;transition:transform .15s ease,background .15s ease,border .15s ease}.sidebar-section-button:hover{background:#fff9;transform:translate(2px)}.sidebar-section.is-open .sidebar-section-button,.sidebar-section.is-locked .sidebar-section-button{background:#fff;border:1px solid var(--panel-border);box-shadow:0 2px 6px #0f172a14}.sidebar-section.is-active:not(.is-open) .sidebar-section-button{background:#ffffff73}.sidebar-section-label{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase}.sidebar-section-caret{width:7px;height:7px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(-45deg);opacity:.6;transition:transform .15s ease}.sidebar-section.is-open .sidebar-section-caret{transform:rotate(45deg)}.sidebar-submenu{list-style:none;margin:6px 0 0;padding:10px 12px;position:absolute;left:calc(100% - 4px);top:0;min-width:220px;max-height:0;overflow:hidden;border-radius:12px;background:#fffffffa;border:1px solid var(--panel-border);box-shadow:0 12px 24px #0f172a2e;opacity:0;transform:translate(8px);pointer-events:none;transition:opacity .18s ease,transform .18s ease,max-height .2s ease;z-index:2}.sidebar-submenu:before{content:"";position:absolute;left:-8px;top:0;width:10px;height:100%}.sidebar-section.is-open .sidebar-submenu{max-height:720px;opacity:1;transform:translate(0);pointer-events:auto}.sidebar-submenu-item{list-style:none;display:flex;flex-direction:column;gap:6px}.sidebar-submenu-item+.sidebar-submenu-item{margin-top:8px;padding-top:8px;border-top:1px solid rgba(182,194,207,.4)}.sidebar-link{padding:8px 10px;border-radius:8px;display:flex;align-items:center;color:var(--text);font-weight:600;transition:background .15s ease,color .15s ease}.sidebar-link:hover{background:#ffffffb3}.sidebar-link.is-active{background:#fffffff2;border:1px solid rgba(182,194,207,.8)}.sidebar-submenu-children{list-style:none;margin:0 0 0 6px;padding:0;display:flex;flex-direction:column;gap:4px}.sidebar-sublink{padding:6px 10px;border-radius:6px;display:flex;align-items:center;font-size:.82rem;color:var(--muted);transition:background .15s ease,color .15s ease}.sidebar-sublink:hover{background:#ffffff8c;color:var(--text)}.sidebar-sublink.is-active{background:#fffffff2;border:1px solid rgba(182,194,207,.8);color:var(--text)}.sidebar-footer{margin-top:auto;font-size:.8rem;color:var(--muted);display:flex;gap:8px;align-items:center}.status-dot{width:10px;height:10px;border-radius:50%;background:var(--success);box-shadow:0 0 8px #2e7d3299}.app-main{position:relative;z-index:1;display:flex;flex-direction:column}.mobile-layout{min-height:100vh;background:var(--bg)}.mobile-layout-header{position:sticky;top:0;z-index:60;display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:linear-gradient(90deg,#2d7a57,#1b5c41 70%);color:#fff;border-bottom:2px solid #0f3b2a}.mobile-layout-brand{font-size:.92rem;letter-spacing:.08em;text-transform:uppercase;font-weight:700}.mobile-menu-toggle{border:1px solid rgba(255,255,255,.45);background:#ffffff29;color:#fff;border-radius:8px;width:36px;height:36px;display:grid;place-items:center;cursor:pointer;font-size:1rem}.mobile-layout-topbar .topbar{border-radius:0;border-top:none;border-bottom-width:1px;padding:12px 14px}.mobile-layout-topbar .topbar-title-chip{display:none}.mobile-layout-content{padding:14px}.mobile-nav-overlay{position:fixed;top:0;right:0;bottom:0;left:0;border:none;background:#0f172a75;opacity:0;pointer-events:none;transition:opacity .16s ease;z-index:70}.mobile-nav-overlay.is-open{opacity:1;pointer-events:auto}.mobile-nav-drawer{position:fixed;top:0;left:0;bottom:0;width:min(320px,90vw);background:var(--panel);border-right:1px solid var(--panel-border);box-shadow:12px 0 24px #0f172a2e;transform:translate(-102%);transition:transform .18s ease;z-index:80;display:flex;flex-direction:column}.mobile-nav-drawer.is-open{transform:translate(0)}.mobile-nav-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:12px;border-bottom:1px solid var(--panel-border)}.mobile-nav-drawer .mobile-menu-toggle{border-color:var(--panel-border);background:var(--bg-secondary);color:var(--text)}.mobile-nav-drawer-content{overflow:auto}.sidebar.sidebar-mobile{min-height:auto;border-right:none;background:transparent;box-shadow:none;padding:12px;gap:12px}.sidebar.sidebar-mobile .sidebar-nav{gap:6px}.sidebar.sidebar-mobile .sidebar-submenu{position:static;left:0;top:0;transform:none;opacity:1;pointer-events:auto;box-shadow:none;border-radius:8px;border:1px solid rgba(182,194,207,.6);margin-top:8px;max-height:0;padding:0 10px}.sidebar.sidebar-mobile .sidebar-section.is-open .sidebar-submenu{max-height:720px;padding:10px}.sidebar.sidebar-mobile .sidebar-submenu:before{display:none}.topbar{position:relative;z-index:30;display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:linear-gradient(90deg,#2d7a57,#1b5c41 70%);color:#fff;border-bottom:2px solid #0f3b2a}.topbar-title{display:flex;align-items:center;gap:12px}.topbar-title-label{font-size:1.2rem;font-weight:600}.topbar-title-chip{font-size:.7rem;background:#ffffff2e;padding:4px 8px;border-radius:999px}.topbar-controls{display:flex;gap:12px;align-items:center}@media (max-width: 900px){.topbar-controls{flex-wrap:wrap;justify-content:flex-end}}.topbar-input{display:flex;flex-direction:column;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;gap:4px}.topbar-input input{padding:6px 10px;border-radius:6px;border:1px solid rgba(255,255,255,.45);background:#ffffff1f;color:#fff;min-width:240px}.topbar-input input::placeholder{color:#ffffffa6}.topbar-input select{padding:6px 10px;border-radius:6px;border:1px solid rgba(255,255,255,.45);background:#ffffff1f;color:#fff;min-width:240px}.topbar-input select option{color:#1a2b3c}.topbar-user{position:relative}.user-trigger{display:flex;align-items:center;gap:10px;padding:6px 12px 6px 8px;border-radius:999px;border:1px solid rgba(255,255,255,.25);background:#ffffff1f;color:#fff;cursor:pointer;transition:background .15s ease,border .15s ease}.user-trigger:hover,.user-trigger.active{background:#fff3;border-color:#ffffff59}.user-avatar{width:36px;height:36px;border-radius:50%;background:#fff3;display:grid;place-items:center;font-weight:600;font-size:.85rem}.user-meta{display:flex;flex-direction:column;align-items:flex-start;line-height:1.15}.user-name{font-size:.85rem;font-weight:600}.user-employee{font-size:.7rem;color:#ffffffbf}.user-menu{position:absolute;right:0;top:calc(100% + 10px);width:280px;background:var(--panel);color:var(--text);border:1px solid var(--panel-border);border-radius:12px;padding:10px;box-shadow:0 14px 30px -22px var(--panel-shadow);z-index:40}.user-menu:before{content:"";position:absolute;top:-6px;right:20px;width:12px;height:12px;background:var(--panel);border-left:1px solid var(--panel-border);border-top:1px solid var(--panel-border);transform:rotate(45deg)}.user-menu-section{padding:8px 6px;border-bottom:1px solid var(--panel-border)}.user-menu-section:last-child{border-bottom:none}.user-menu-title{font-weight:600;font-size:.8rem;margin-bottom:6px}.user-menu-note{margin:0 0 8px;font-size:.7rem}.user-menu-button{width:100%;justify-content:center}.user-menu-meta{display:flex;flex-direction:column;gap:4px;font-size:.75rem}.user-menu-field{display:flex;flex-direction:column;gap:6px;font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;margin-top:8px}.user-menu-field select,.user-menu-field input{padding:6px 10px;border-radius:6px;border:1px solid var(--panel-border);background:var(--bg-secondary);color:var(--text)}.user-menu-field select option{color:var(--text)}.user-menu-message{margin-top:6px;font-size:.7rem}.user-menu-message.error{color:var(--danger)}.user-menu-message.success{color:var(--success)}.user-menu-actions{display:flex;justify-content:flex-end}.user-menu .button.ghost{background:var(--bg-secondary);color:var(--text);border:1px solid var(--panel-border)}.user-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#080e1866;display:flex;align-items:center;justify-content:center;z-index:100}.user-dialog{width:min(420px,90vw);background:var(--panel);color:var(--text);border:1px solid var(--panel-border);border-radius:12px;padding:20px;box-shadow:0 20px 50px -30px var(--panel-shadow);display:flex;flex-direction:column;gap:12px}.user-dialog h3{margin:0}.user-dialog-field{display:flex;flex-direction:column;gap:6px;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em}.user-dialog-field input{padding:8px 10px;border-radius:8px;border:1px solid var(--panel-border);background:var(--bg-secondary);color:var(--text)}.user-dialog-actions{display:flex;justify-content:flex-end;gap:8px}.app-content{padding:24px}.page{display:flex;flex-direction:column;gap:20px}.panel{background:var(--panel);border:1px solid var(--panel-border);border-radius:12px;padding:20px;box-shadow:0 10px 20px -16px var(--panel-shadow),inset 0 0 0 1px #fff}.panel-header{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px}.panel h2{margin:0;font-size:1.2rem}.muted{color:var(--muted)}.filters{display:flex;gap:12px;flex-wrap:wrap}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.pagination-controls{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin:10px 0 12px;padding:8px 10px;border:1px solid var(--panel-border);border-radius:8px;background:#f5f9ff}.pagination-summary{display:flex;align-items:center;gap:8px;font-size:.85rem}.pagination-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.pagination-pages{display:inline-flex;align-items:center;gap:4px}.pagination-size{min-width:82px}.pagination-size .filter-select{min-width:68px}.pagination-button{min-width:34px;padding:6px 10px;border-radius:6px;background:#fff;color:#143a56;border:1px solid #b9cde0}.pagination-button:disabled{opacity:.45;cursor:default}.pagination-current{background:#237a571f!important;color:var(--primary-dark)!important;border:1px solid rgba(35,122,87,.45)!important}.filter-input,.filter-select{padding:8px 10px;border:1px solid var(--panel-border);border-radius:8px;background:var(--bg-secondary);font-family:IBM Plex Sans,Segoe UI,sans-serif}.filter-input:focus,.filter-select:focus{outline:2px solid rgba(35,122,87,.4)}.table-wrap{overflow:auto}.data-table{width:100%;border-collapse:collapse;font-size:.92rem}.invoice-grid{min-width:1100px}.invoice-grid thead th,.invoice-grid tbody td{padding:6px 8px;font-size:.82rem}.invoice-grid .table-input,.invoice-grid .table-select{padding:4px 6px;font-size:.8rem}.data-table thead th{text-align:left;padding:10px 12px;background:linear-gradient(180deg,#e4ebf3 0%,var(--table-header) 100%);border-bottom:2px solid var(--panel-border);position:sticky;top:0;z-index:1}.data-table tbody td{padding:10px 12px;border-bottom:1px solid #e1e7ef}.data-table tbody tr:nth-child(2n){background:var(--table-row)}.data-table tbody tr{cursor:pointer}.data-table .row-toggle{background:#dbe4ef;color:#1b2a3a;border:1px solid #9fb2c8;font-weight:700;min-width:30px;padding:4px 8px}.data-table .row-toggle:hover{background:#cfd9e6}.data-table .row-toggle:focus{outline:2px solid rgba(27,42,58,.4)}.expanded-row>td{background:#eef3f9;border-top:1px solid #cbd6e4}.expanded-row .data-table thead th{background:linear-gradient(180deg,#dfe7f2,#cad6e4)}.expanded-row .data-table tbody td{background:#f6f9fd}.data-table.compact thead th,.data-table.compact tbody td{padding:8px 10px;font-size:.85rem}.terminal-log{margin-top:12px;background:#0f1b2a;color:#dbe7f6;border:1px solid #1f2f46;border-radius:10px;padding:10px 12px;font-family:IBM Plex Mono,SFMono-Regular,monospace;font-size:.75rem;max-height:180px;overflow:auto}.terminal-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:#8fb2dd;margin-bottom:6px}.terminal-line{display:grid;grid-template-columns:70px 70px 1fr;gap:8px;padding:2px 0}.terminal-time{color:#8fa3bf}.terminal-status{text-transform:uppercase;font-weight:600}.terminal-status.success{color:#7fd18b}.terminal-status.failure{color:#ff8a80}.terminal-status.skipped{color:#ffd56a}.terminal-message{color:#dbe7f6;word-break:break-word}.table-checkbox{width:18px;height:18px;accent-color:var(--primary)}.invoice-top{display:grid;grid-template-columns:1.35fr 1fr;gap:12px}.invoice-bottom{display:grid;grid-template-columns:1.2fr .8fr;gap:12px;margin-top:12px}.invoice-card{background:var(--bg-secondary);border:1px solid var(--panel-border);border-radius:10px;padding:12px;box-shadow:inset 0 0 0 1px #fff}.invoice-card h3{margin:0 0 8px}.invoice-card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.invoice-card .form-grid{gap:10px}.invoice-card .form-field{gap:4px;font-size:.8rem}.invoice-card .form-textarea{padding:8px}.customer-lookup{position:relative}.lookup-results{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid var(--panel-border);border-radius:10px;padding:6px;max-height:220px;overflow:auto;box-shadow:0 12px 20px -18px #0f172a40;z-index:10}.lookup-item{display:flex;justify-content:space-between;width:100%;padding:8px 10px;border:none;background:transparent;border-radius:8px;cursor:pointer;text-align:left;font-size:.9rem}.lookup-item:hover{background:var(--table-row)}.item-lookup{position:relative}.item-lookup .lookup-results{max-height:220px}.item-lookup .lookup-item{display:flex;justify-content:space-between;gap:8px}.item-quick-add{margin:10px 0 12px}.quick-add{margin-top:12px;padding:12px;border-radius:10px;background:#fff;border:1px dashed #cad5e2}.address-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-top:12px}.form-grid.two-col{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.totals-card{align-self:start}.totals-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px dashed #d7e0ea;font-size:.9rem}.totals-row.total{font-weight:700;border-bottom:none;font-size:1rem;padding-top:10px}.totals-row.minor{border-bottom:none;font-size:.82rem;color:var(--muted)}.tax-breakdown{margin-top:8px}@media (max-width: 1100px){.invoice-top,.invoice-bottom{grid-template-columns:1fr}}.table-input,.table-select{width:100%;padding:6px 8px;border-radius:6px;border:1px solid #d1d9e3;background:#fff;font-size:.82rem;font-family:IBM Plex Sans,Segoe UI,sans-serif}.table-input:focus,.table-select:focus{outline:2px solid rgba(35,122,87,.3);border-color:var(--primary)}.pill{display:inline-flex;padding:4px 10px;border-radius:999px;font-size:.72rem;font-weight:600;text-transform:capitalize;background:#e8eef4;color:var(--muted)}.pill.active,.pill.posted,.pill.sent,.pill.paid,.pill.completed,.pill.processed{background:#2e7d322e;color:#1b5e20}.pill.draft,.pill.planned,.pill.new{background:#2196f333;color:#0d47a1}.pill.on_hold,.pill.void,.pill.inactive,.pill.archived{background:#b26a0033;color:#7a4b00}.pill.closed{background:#b3261e2e;color:var(--danger)}.pill.muted{background:#e8eef4;color:var(--muted)}.empty-state{padding:24px;text-align:center;color:var(--muted)}.error-banner{background:#b3261e1f;color:var(--danger);padding:10px 12px;border-radius:8px;border:1px solid rgba(179,38,30,.3);margin-bottom:12px}.success-banner{background:#2e7d321f;color:#1b5e20;padding:10px 12px;border-radius:8px;border:1px solid rgba(46,125,50,.3);margin-bottom:12px}.info-banner{background:#2196f31f;color:#0d47a1;padding:10px 12px;border-radius:8px;border:1px solid rgba(33,150,243,.3);margin-bottom:12px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-top:16px}.stat-card{background:linear-gradient(180deg,#fff,#f3f7fb);border-radius:12px;border:1px solid #c9d4df;padding:16px}.stat-label{font-size:.8rem;color:var(--muted)}.stat-value{font-size:1.6rem;font-weight:700;margin-top:6px}.stat-hint{font-size:.72rem;color:var(--muted);margin-top:4px}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.quick-card{padding:16px;border-radius:12px;border:1px solid #d0dae6;background:#f7fafc}.quick-card h3{margin:0 0 8px}.chip{display:inline-flex;padding:4px 10px;border-radius:999px;background:#237a5726;color:var(--primary-dark);font-size:.72rem;font-weight:600}.button{border:none;cursor:pointer;padding:8px 14px;border-radius:8px;font-weight:600}.button.primary{background:var(--primary);color:#fff}.button.ghost{background:#ffffff2e;color:#fff;border:1px solid rgba(255,255,255,.4)}.button.danger{background:#b3261e1f;color:var(--danger);border:1px solid rgba(179,38,30,.4)}.split-layout{display:grid;grid-template-columns:minmax(280px,1fr) minmax(320px,1.3fr);gap:20px}.customer-center,.job-center{align-items:start}.list-panel,.form-panel{background:#f8fbff;border:1px solid #d1dbe7;border-radius:12px;padding:16px}.customer-detail,.job-detail{min-height:420px}.customer-detail-body,.job-detail-body{display:flex;flex-direction:column;gap:16px}.customer-transactions,.job-transactions{display:flex;flex-direction:column;gap:12px}.mobile-stack{display:flex;flex-direction:column;gap:16px}.mobile-section{background:#f8fbff;border:1px solid #d1dbe7;border-radius:12px;padding:16px}.mobile-section-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.mobile-toolbar{margin-bottom:12px}.mobile-filters{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.mobile-filter-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.mobile-list{display:flex;flex-direction:column;gap:10px}.mobile-card{border:1px solid var(--panel-border);background:#fff;border-radius:12px;padding:12px;text-align:left;display:flex;flex-direction:column;gap:6px;cursor:pointer;transition:border .15s ease,box-shadow .15s ease,transform .15s ease}.mobile-card:hover{border-color:#2d68c466;box-shadow:0 6px 12px #0f172a14;transform:translateY(-1px)}.mobile-card.selected{border-color:var(--primary);box-shadow:0 6px 14px #2d68c42e}.mobile-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.mobile-card-title{font-weight:600}.mobile-card-meta{font-size:.82rem;color:var(--muted)}.mobile-actions{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.mobile-field-grid{display:grid;grid-template-columns:1fr;gap:12px}.mobile-detail-card{background:#f8fbff;border:1px solid #d1dbe7;border-radius:12px;padding:16px}.mobile-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:12px}.mobile-detail-section{margin-top:16px}.mobile-pill-wrap{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.customer-notes,.job-notes{padding-top:8px}.customer-header,.job-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px}.customer-title-row,.job-title-row{display:flex;align-items:center;gap:12px}.customer-meta,.job-meta{display:flex;gap:16px;flex-wrap:wrap;color:var(--muted);font-size:.85rem}.customer-header-actions,.job-header-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.customer-tabs,.customer-filters,.job-tabs,.job-filters{margin:12px 0 16px;flex-wrap:wrap}.customer-empty,.job-empty{text-align:center;padding:40px 20px}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:16px}.summary-card{background:var(--panel);border:1px solid var(--panel-border);border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:6px}.customer-overview-details,.job-overview-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.row-link{cursor:pointer}.row-link:hover{background:#0f172a0f}.numeric{text-align:right}.amount-negative{color:var(--danger)}.amount-positive{color:var(--success)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:flex-start;justify-content:center;padding:40px 20px;z-index:50;overflow:auto}.modal-panel{background:var(--panel);border:1px solid var(--panel-border);border-radius:14px;width:min(960px,96vw);box-shadow:0 18px 40px #0f172a40;padding:20px}.modal-panel-wide{width:min(1100px,96vw)}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px}.modal-body{display:flex;flex-direction:column;gap:20px}.list-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.view-toggle{display:flex;gap:8px;flex-wrap:wrap}.toggle-group{display:inline-flex;gap:4px;padding:4px;border-radius:999px;background:#1a2b3c14;border:1px solid rgba(26,43,60,.15)}.multi-select{position:relative;display:inline-block}.multi-select-trigger{min-width:220px;text-align:left}.multi-select-menu{position:absolute;top:calc(100% + 8px);left:0;z-index:10;background:var(--panel);border:1px solid var(--panel-border);border-radius:10px;box-shadow:0 12px 24px #0f172a2e;padding:10px;min-width:240px;max-height:240px;overflow:auto}.job-picker,.job-picker .multi-select-trigger{width:100%}.job-picker-menu{width:100%;min-width:0}.job-picker-menu .filter-input{margin-bottom:8px;width:100%}.job-picker-option{width:100%;border:none;background:transparent;border-radius:8px;padding:8px 10px;text-align:left;cursor:pointer;font-size:.85rem;color:var(--text)}.job-picker-option:hover{background:var(--table-row)}.job-picker-option.selected{background:#237a5726;color:var(--primary-dark);font-weight:600}.multi-select-item{display:flex;align-items:center;gap:8px;padding:6px;font-size:.85rem;cursor:pointer}.multi-select-item input{accent-color:var(--primary)}.multi-select-divider{height:1px;background:#0f172a1f;margin:6px 0}.toggle-button{border:none;cursor:pointer;padding:6px 14px;border-radius:999px;font-weight:600;background:transparent;color:var(--muted);opacity:.6;transition:all .15s ease}.toggle-button.active{background:var(--primary);color:#fff;opacity:1;box-shadow:0 6px 12px -8px #0f172a59}.toggle-button:not(.active):hover{opacity:.85;color:var(--text)}.settings-layout{grid-template-columns:minmax(220px,.7fr) minmax(360px,1.3fr)}.settings-nav{display:flex;flex-direction:column;gap:8px}.settings-nav-button{border:1px solid transparent;border-radius:10px;padding:10px 12px;text-align:left;font-weight:600;background:#fff9;color:var(--text);cursor:pointer;transition:border .15s ease,box-shadow .15s ease,background .15s ease}.settings-nav-button:hover{border-color:#b6c2cfe6;box-shadow:0 4px 10px #0f172a14}.settings-nav-button.active{border-color:var(--panel-border);background:#fff;box-shadow:0 6px 12px #0f172a1f}.calendar-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.calendar-jump-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.calendar-jump-controls .form-field{margin:0;min-width:120px}.calendar-jump-controls .form-field span{display:block;font-size:.72rem}.calendar-tools{margin-top:8px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.calendar-legend{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.calendar-legend-item{display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(15,23,42,.15);border-radius:999px;padding:2px 8px;font-size:.74rem;background:#ffffffbf}.calendar-legend-swatch{width:10px;height:10px;border-radius:50%}.calendar-table{table-layout:fixed;width:100%}.calendar-table th,.calendar-table td{width:14.285%;text-align:center}.calendar-cell{vertical-align:top;padding:10px 6px}.calendar-day-button{border:1px solid #bfd0e3;background:#fff;color:var(--primary-dark);border-radius:6px;padding:2px 8px;min-width:30px;font-size:.74rem;font-weight:700;line-height:1.2;cursor:pointer}.calendar-day-button:hover{background:#edf4fb;border-color:#9bb5d2}.calendar-day-button:focus-visible{outline:2px solid rgba(35,122,87,.35);outline-offset:1px}.calendar-day-button.calendar-outside{background:#f3f6fa;border-color:#d4dfeb}.calendar-cell-total{min-height:16px}.calendar-employee-list{display:flex;flex-direction:column;gap:3px;margin-top:4px}.calendar-employee-chip{color:#fff;border-radius:6px;padding:2px 4px;font-size:.66rem;display:flex;align-items:center;justify-content:space-between;gap:4px;opacity:.95}.calendar-employee-chip-button{border:none;background:transparent;padding:0;width:100%;text-align:left;cursor:pointer}.calendar-employee-chip-button:focus-visible .calendar-employee-chip,.calendar-employee-chip-button:hover .calendar-employee-chip{box-shadow:0 0 0 2px #ffffff73}.calendar-employee-code{font-weight:700;letter-spacing:.02em}.calendar-employee-more{font-size:.66rem;color:var(--muted)}.calendar-entry-modal{width:min(980px,96vw)}.calendar-entry-notes{max-width:320px;white-space:normal;word-break:break-word}.calendar-outside{color:var(--muted);opacity:.6}.row-selected{background:#237a571f}.form-section{border-bottom:1px solid #d5dfeb;padding-bottom:16px;margin-bottom:16px}.form-section h3{margin:0 0 12px;font-size:1rem;display:flex;align-items:center;gap:10px}.mode-indicator{font-size:.7rem;padding:4px 8px;border-radius:999px;background:#237a5726;color:var(--primary-dark);text-transform:uppercase;letter-spacing:.08em}.form-summary{display:flex;gap:16px;flex-wrap:wrap;align-items:center;margin-bottom:12px;padding:10px 12px;border-radius:10px;background:#eef3f8;border:1px solid #d6e0ec}.form-summary span{display:block;font-size:.72rem;color:var(--muted)}.form-summary strong{display:block;font-weight:600;margin-top:2px}.mono{font-family:IBM Plex Mono,SFMono-Regular,monospace;font-size:.72rem;word-break:break-all}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.inline-panel{grid-column:1 / -1;border:1px solid var(--panel-border);background:#f8fafc;border-radius:10px;padding:12px}.detail-panel{margin-top:12px;padding:12px;border:1px solid var(--panel-border);border-radius:10px;background:#f8fafc}.detail-row{margin-bottom:6px;font-size:.85rem}.code-block{margin-top:8px;padding:10px;border-radius:8px;background:#111;color:#eee;font-size:.75rem;white-space:pre-wrap}.inline-panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}.form-field{display:flex;flex-direction:column;gap:6px;font-size:.85rem}.required{color:var(--danger);font-weight:700}.form-hint{font-size:.75rem;color:var(--muted);margin-bottom:10px}.toggle{display:flex;align-items:center;gap:8px;font-size:.85rem;margin-bottom:8px}.form-field input,.form-field select{padding:8px 10px;border-radius:8px;border:1px solid var(--panel-border);background:#fff}.form-field.checkbox{flex-direction:row;align-items:center;gap:10px;padding-top:18px}.form-field.checkbox input{width:auto;margin:0}.form-textarea{width:100%;padding:10px;border-radius:8px;border:1px solid var(--panel-border);background:#fff;font-family:\"IBM Plex Sans\",\"Segoe UI\",sans-serif}.form-actions{display:flex;justify-content:flex-end;gap:10px}.form-actions .button.ghost{background:#f1f4f8;color:var(--text);border:1px solid #cdd7e3}.row-actions{display:flex;gap:8px;justify-content:flex-end}.link-button{background:none;border:none;color:var(--primary-dark);cursor:pointer;padding:0;font-weight:600;font-size:.8rem}.link-button.danger{color:var(--danger)}.drop-zone-wrap{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.drop-zone{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border-radius:12px;border:1px dashed #c7d3e1;background:#f7faff;font-size:.85rem}.drop-zone.active{border-color:var(--primary);background:#237a5714}.file-input{display:none}.drop-zone-wrap .button.ghost{background:#eef3f8;color:var(--text);border:1px solid #cdd7e3}.ai-summary{display:flex;gap:16px;flex-wrap:wrap;padding:10px 12px;border-radius:10px;background:#eef3f8;border:1px solid #d6e0ec;margin-bottom:12px}.ai-meta{display:flex;flex-direction:column;gap:4px}.ai-note{width:100%;font-size:.8rem;color:var(--muted)}.ai-suggestions{display:grid;gap:8px;margin-bottom:12px}.ai-suggestion{display:flex;justify-content:space-between;gap:12px;padding:8px 10px;border-radius:10px;border:1px solid #d6e0ec;background:#fff;font-size:.85rem}.ai-confidence{font-weight:600;color:var(--primary-dark)}.ai-actions{justify-content:flex-start;margin-bottom:8px}.link-button:disabled{opacity:.45;cursor:not-allowed}.activity-block{margin-bottom:16px}.activity-block h4{margin:0 0 8px;font-size:.95rem}.login{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at top,#f4f8fb,#dfe7f0 60%,#cdd8e4)}.login-panel{width:min(420px,100%);background:var(--panel);border-radius:16px;padding:28px;border:1px solid var(--panel-border);box-shadow:0 20px 40px -24px var(--panel-shadow)}.login-header{display:flex;gap:16px;align-items:center;margin-bottom:24px}.login-header h1{margin:0;font-size:1.4rem}.login-form{display:flex;flex-direction:column;gap:14px}.login-form label{display:flex;flex-direction:column;gap:6px;font-size:.85rem}.login-form input{padding:10px 12px;border-radius:8px;border:1px solid var(--panel-border);background:var(--bg-secondary)}.login-footer{margin-top:16px;font-size:.75rem;color:var(--muted)}.employees-page .panel{padding:11px}.employees-page .panel-header{margin-bottom:8px}.employees-page .filters{gap:6px}.employees-page .split-layout{gap:10px}.employees-page .list-panel,.employees-page .form-panel{padding:10px}.employees-page .data-table thead th{padding:6px}.employees-page .data-table tbody td{padding:5px 6px}.employees-page .filter-input,.employees-page .filter-select{padding:4px 6px}.employees-page .multi-select-trigger{min-width:112px}.employees-page .form-section{padding-bottom:8px;margin-bottom:8px}.employees-page .form-summary{margin-bottom:6px;padding:6px 7px;gap:8px}.employees-page .form-grid{gap:6px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.employees-page .form-field{gap:3px}.employees-page .form-field input,.employees-page .form-field select{padding:5px 6px}.employees-page .form-textarea{padding:6px}.employees-page .form-actions{gap:6px}.employees-page .button{padding:5px 8px}.employees-page .pill{padding:2px 6px}@media (max-width: 767px){.app-shell{grid-template-columns:1fr}.sidebar,.sidebar-nav{flex-direction:row;flex-wrap:wrap}.sidebar-section{width:100%}.sidebar-submenu{position:static;transform:none;box-shadow:none;margin-top:8px}.mobile-filter-row,.mobile-detail-grid{grid-template-columns:1fr}.mobile-section .button,.mobile-actions .button{padding:10px 16px;font-size:.95rem}.app-content{padding:16px}.split-layout{grid-template-columns:1fr}}
