@charset "UTF-8";:root{--color-bg: #f6f7fb;--color-surface: #ffffff;--color-border: #e6e8f0;--color-text: #16182b;--color-text-muted: #6b7080;--color-accent: #4f46e5;--color-accent-hover: #4338ca;--color-accent-soft: #eef0fd;--color-success: #15803d;--color-success-soft: #e8f6ec;--color-danger: #d92d20;--color-danger-soft: #fdeceb;--color-warning: #b45309;--color-warning-soft: #fdf4e3;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--shadow-sm: 0 1px 2px rgba(16, 24, 40, .06);--shadow-md: 0 4px 16px rgba(16, 24, 40, .08);--shadow-lg: 0 12px 32px rgba(16, 24, 40, .12);--sidebar-width: 232px}:root[data-theme=dark]{--color-bg: #14151f;--color-surface: #1c1d2b;--color-border: #2e2f42;--color-text: #eceef5;--color-text-muted: #9a9cb5;--color-accent: #6f68f0;--color-accent-hover: #8079f5;--color-accent-soft: #28274a;--color-success: #3ddc84;--color-success-soft: #173324;--color-danger: #ff6b61;--color-danger-soft: #3a2024;--color-warning: #f0b454;--color-warning-soft: #3a2e16;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .5)}*{box-sizing:border-box}body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased}h1,h2,h3{font-weight:700;letter-spacing:-.01em}.shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);flex-shrink:0;background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;padding:20px 14px}.sidebar .brand{display:flex;align-items:center;gap:10px;padding:4px 10px 20px;margin-bottom:10px}.sidebar .brand-mark{background:var(--color-accent);color:#fff;font-weight:700;font-size:13px;width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.sidebar .brand-name{font-size:16px;font-weight:700;color:var(--color-text)}.sidebar nav{display:flex;flex-direction:column;gap:2px}.sidebar nav a{display:flex;align-items:center;gap:11px;color:var(--color-text-muted);text-decoration:none;font-size:14px;font-weight:500;padding:9px 12px;border-radius:var(--radius-sm)}.sidebar nav a svg{width:18px;height:18px;flex-shrink:0}.sidebar nav a.active,.sidebar nav a:hover{color:var(--color-accent);background:var(--color-accent-soft)}.sidebar .nav-divider{height:1px;background:var(--color-border);margin:12px 6px}.sidebar .hire-me-link{color:var(--color-accent)!important;font-weight:600}.topbar{height:64px;flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:0 28px;border-bottom:1px solid var(--color-border);background:var(--color-surface)}.topbar-left{display:flex;align-items:center;gap:14px}.topbar .page-title{font-size:16px;font-weight:700}.menu-toggle{display:none;background:transparent;color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:7px;cursor:pointer}.menu-toggle svg{width:18px;height:18px;display:block}.menu-toggle:hover{background:var(--color-bg)}.sidebar-backdrop{display:none}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:7px;cursor:pointer}.theme-toggle svg{width:16px;height:16px;display:block}.theme-toggle:hover{background:var(--color-bg);color:var(--color-accent)}.btn-cta{display:inline-flex;align-items:center;gap:6px;background:var(--color-accent);color:#fff;text-decoration:none;padding:8px 16px;border-radius:999px;font-size:13px;font-weight:600}.btn-cta:hover{background:var(--color-accent-hover)}.main-area{flex:1;display:flex;flex-direction:column;min-width:0}.content{flex:1;max-width:1180px;width:100%;margin:0 auto;padding:28px 32px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.page-header h2{margin:0;font-size:22px}.page-header p{margin:4px 0 0;color:var(--color-text-muted);font-size:13px}.panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:22px 24px;box-shadow:var(--shadow-sm)}.deployment-panel{display:flex;gap:32px;margin-bottom:24px}.deployment-item{display:flex;flex-direction:column;gap:2px}.deployment-label{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted)}.deployment-value{font-size:20px;font-weight:700;font-family:SFMono-Regular,Consolas,monospace;color:var(--color-accent)}.deployment-sub{font-size:12px;color:var(--color-text-muted)}.pager{display:flex;align-items:center;justify-content:space-between;margin-top:14px;padding-top:14px;border-top:1px solid var(--color-border);font-size:13px;color:var(--color-text-muted)}.pager-size{display:flex;align-items:center;gap:6px}.pager-size select{padding:4px 8px}.pager-controls{display:flex;align-items:center;gap:10px}.pager-status{min-width:90px;text-align:center}.panel h2{margin-top:0}button,.btn{font-family:inherit}button{background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:9px 16px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s ease}button:hover{background:var(--color-accent-hover)}button:disabled{background:#c8cbe6;cursor:not-allowed}button.btn-secondary{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border)}button.btn-secondary:hover{background:var(--color-bg);color:var(--color-text)}button.btn-ghost{background:transparent;color:var(--color-text-muted);padding:6px 10px}button.btn-ghost:hover{background:var(--color-bg);color:var(--color-text)}button.btn-danger-ghost{background:transparent;color:var(--color-danger);padding:6px 10px}button.btn-danger-ghost:hover{background:var(--color-danger-soft)}input,select,textarea{font-family:inherit;padding:9px 11px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:13px;color:var(--color-text);background:var(--color-surface);outline:none;transition:border-color .15s ease,box-shadow .15s ease}input:focus,select:focus,textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}.field{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}.field label{font-size:12.5px;font-weight:600;color:var(--color-text-muted)}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.checkbox-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--color-text-muted)}.filterable-th{position:relative}.filterable-th span{vertical-align:middle}.col-filter-btn{background:transparent;border:none;cursor:pointer;padding:2px 4px;margin-left:4px;color:var(--color-text-muted);vertical-align:middle}.col-filter-btn svg{width:13px;height:13px}.col-filter-btn.active{color:var(--color-accent)}.col-filter-dropdown{position:absolute;top:100%;left:0;z-index:50;margin-top:4px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:10px;width:220px;text-transform:none;font-weight:400}.col-filter-dropdown input[type=text]{width:100%;margin-bottom:8px;padding:6px 8px;font-size:13px;border:1px solid var(--color-border);border-radius:var(--radius-sm)}.col-filter-list{max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:6px;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);padding:6px 0}.col-filter-list .checkbox-row{font-weight:400}.col-filter-actions{display:flex;justify-content:space-between;margin-top:8px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13.5px}th,td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--color-border);white-space:nowrap}th{color:var(--color-text-muted);text-transform:uppercase;font-size:11px;font-weight:600;letter-spacing:.04em}tbody tr:hover{background:var(--color-bg)}.row-actions{display:flex;gap:4px}.status-pill{display:inline-flex;padding:3px 10px;border-radius:999px;font-size:11.5px;font-weight:600}.status-active,.status-paid{background:var(--color-success-soft);color:var(--color-success)}.status-onhold,.status-sent{background:var(--color-warning-soft);color:var(--color-warning)}.status-completed,.status-draft{background:var(--color-accent-soft);color:var(--color-accent)}.empty-state{text-align:center;padding:48px 20px;color:var(--color-text-muted)}.empty-state .empty-icon{font-size:28px;margin-bottom:8px;opacity:.6}.empty-state p{margin:4px 0 0;font-size:13.5px}.loading-state{display:flex;align-items:center;justify-content:center;gap:10px;padding:48px 0;color:var(--color-text-muted);font-size:13.5px}.spinner{width:18px;height:18px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-backdrop{position:fixed;inset:0;background:#10122173;display:flex;align-items:center;justify-content:center;z-index:900;padding:20px}.modal-card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;padding:24px 26px}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.modal-header h3{margin:0;font-size:17px}.modal-close{background:transparent;color:var(--color-text-muted);border:none;font-size:18px;padding:2px 6px;cursor:pointer}.modal-close:hover{background:var(--color-bg);border-radius:var(--radius-sm)}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:6px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:18px 20px;box-shadow:var(--shadow-sm)}.stat-card .stat-icon{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--color-accent-soft);color:var(--color-accent);display:flex;align-items:center;justify-content:center;margin-bottom:12px}.stat-card .stat-icon svg{width:18px;height:18px}.stat-value{font-size:24px;font-weight:800;color:var(--color-text);line-height:1.1}.stat-label{font-size:12.5px;color:var(--color-text-muted);margin-top:4px}.chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:22px 0 28px}.chart-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:18px 20px;box-shadow:var(--shadow-sm)}.chart-card h3{margin:0 0 14px;font-size:14px;color:var(--color-text)}.section-heading{font-size:15px;font-weight:700;margin:26px 0 12px}.hero-card{background:linear-gradient(135deg,var(--color-accent) 0%,#7c3aed 100%);color:#fff;border-radius:var(--radius-lg);padding:36px 32px;margin-bottom:24px}.hero-card h2{margin:0 0 8px;font-size:24px;color:#fff}.hero-card p{margin:0 0 20px;font-size:14px;color:#ffffffe0;max-width:560px;line-height:1.5}.hero-actions{display:flex;gap:10px;flex-wrap:wrap}.hero-actions a{text-decoration:none}.btn-on-hero{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:999px;font-size:13px;font-weight:600}.btn-on-hero-primary{background:#fff;color:var(--color-accent)}.btn-on-hero-secondary{background:#ffffff24;color:#fff;border:1px solid rgba(255,255,255,.4)}.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.service-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px 18px}.service-card .service-icon{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--color-accent-soft);color:var(--color-accent);display:flex;align-items:center;justify-content:center;margin-bottom:10px}.service-card .service-icon svg{width:16px;height:16px}.service-card h4{margin:0 0 4px;font-size:13.5px}.integration-status{display:inline-block;margin-left:6px;padding:1px 8px;border-radius:999px;font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;background:var(--color-warning-soft);color:var(--color-warning);vertical-align:middle}.integration-status.live{background:var(--color-success-soft);color:var(--color-success)}.service-card p{margin:0;font-size:12.5px;color:var(--color-text-muted);line-height:1.45}.contact-row{display:flex;gap:14px;margin-top:18px;flex-wrap:wrap}.contact-chip{display:flex;align-items:center;gap:8px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:10px 16px;font-size:13px;color:var(--color-text)}.toast-stack{position:fixed;top:18px;right:18px;display:flex;flex-direction:column;gap:8px;z-index:1000}.toast{display:flex;align-items:center;gap:12px;padding:11px 16px;border-radius:var(--radius-md);font-size:13px;font-weight:500;color:#fff;box-shadow:var(--shadow-md);min-width:240px;max-width:360px}.toast-error{background:var(--color-danger)}.toast-success{background:var(--color-success)}.toast button{background:transparent;border:none;color:#fff;font-size:16px;line-height:1;padding:0 0 0 8px;cursor:pointer}.app-tooltip{position:fixed;z-index:5000;background:#1f2030;color:#fff;font-size:12px;font-weight:500;padding:6px 10px;border-radius:var(--radius-sm);box-shadow:var(--shadow-md);pointer-events:none;opacity:0;transform:translateY(4px);transition:opacity .12s ease,transform .12s ease;max-width:240px;line-height:1.35}.app-tooltip.visible{opacity:1;transform:translateY(0)}.tour-backdrop{position:fixed;inset:0;background:#0f11218c;z-index:4000}.tour-highlight{position:relative;z-index:4001;background:var(--color-accent-soft)!important;color:var(--color-accent)!important;box-shadow:0 0 0 4px #4f46e559;border-radius:var(--radius-sm)}.tour-card{position:fixed;z-index:4002;background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:16px 18px;width:280px}.tour-step-count{font-size:11px;font-weight:700;color:var(--color-accent);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}.tour-card h4{margin:0 0 6px;font-size:15px}.tour-card p{margin:0 0 14px;font-size:13px;color:var(--color-text-muted)}.tour-actions{display:flex;justify-content:space-between;align-items:center}.tour-nav-buttons{display:flex;gap:8px}.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg);padding:20px}.auth-card{width:100%;max-width:420px}.auth-card h2{margin:4px 0;font-size:20px}.auth-sub{font-size:13px;color:var(--color-text-muted);margin:0 0 18px;line-height:1.5}.auth-tabs{display:flex;gap:8px;margin-bottom:18px}.auth-tabs button{flex:1}.google-signin-wrap{display:flex;justify-content:center;margin:16px 0 6px}.auth-divider{display:flex;align-items:center;text-align:center;margin:14px 0 18px;color:var(--color-text-muted);font-size:12px}.auth-divider:before,.auth-divider:after{content:"";flex:1;border-bottom:1px solid var(--color-border)}.auth-divider span{padding:0 10px}.auth-card form button[type=submit]{width:100%;margin-top:6px}.field-hint{font-size:11.5px;color:var(--color-text-muted)}.field-error{font-size:11.5px;color:var(--color-danger)}.auth-footer-link{text-align:center;margin-top:16px;font-size:13px}.company-banner{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--color-text-muted);background:var(--color-accent-soft);color:var(--color-accent);padding:4px 12px;border-radius:999px;font-weight:600}.login-actions{display:flex;align-items:center;gap:10px}.user-chip{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--color-text-muted)}.user-chip strong{color:var(--color-text)}.role-badge{font-size:10.5px;font-weight:700;text-transform:uppercase;padding:2px 8px;border-radius:999px;background:var(--color-accent-soft);color:var(--color-accent)}.gate-notice{display:flex;align-items:center;justify-content:space-between;background:var(--color-warning-soft);color:var(--color-warning);padding:10px 16px;border-radius:var(--radius-md);font-size:13px;margin-bottom:16px}.gate-notice a{color:var(--color-warning);font-weight:600;text-decoration:underline}.auth-error-notice{background:var(--color-danger-soft);color:var(--color-danger)}.invoice-doc{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.invoice-doc-header{display:flex;align-items:flex-start;justify-content:space-between;padding:26px 28px;background:linear-gradient(135deg,var(--color-accent),var(--color-accent-hover));color:#fff}.invoice-doc-label{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;opacity:.85}.invoice-doc-number{font-size:26px;font-weight:700;margin-top:4px}.invoice-doc-brand{font-size:14px;font-weight:700;opacity:.9}.invoice-doc-body{padding:26px 28px;background:var(--color-surface)}.invoice-doc-section-label{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:6px}.invoice-doc-billto{margin-bottom:22px}.invoice-doc-client-name{font-size:16px;font-weight:700}.invoice-doc-muted{font-size:13px;color:var(--color-text-muted)}.invoice-doc-meta{width:100%;border-collapse:collapse;font-size:13.5px}.invoice-doc-meta td{padding:8px 0;border-bottom:1px solid var(--color-border)}.invoice-doc-meta td:first-child{color:var(--color-text-muted)}.invoice-doc-meta td:last-child{text-align:right;font-weight:600}.invoice-doc-total{display:flex;align-items:baseline;justify-content:space-between;margin-top:22px;padding-top:18px;border-top:2px solid var(--color-text);font-size:14px;color:var(--color-text-muted)}.invoice-doc-total-amount{font-size:30px;font-weight:700;color:var(--color-accent)}.invoice-doc-footer{text-align:center;font-size:11.5px;color:var(--color-text-muted);padding:14px;border-top:1px solid var(--color-border);background:var(--color-bg)}@media print{body *{visibility:hidden}.invoice-doc,.invoice-doc *{visibility:visible}.invoice-doc{position:absolute;top:0;left:0;width:100%}.no-print,.ai-chat-fab,.ai-chat-panel{display:none!important}}.task-progress-bar{display:inline-block;width:90px;height:6px;background:var(--color-border);border-radius:999px;overflow:hidden;vertical-align:middle;margin-right:6px}.task-progress-fill{height:100%;background:var(--color-accent);border-radius:999px}.task-progress-label{font-size:12px;color:var(--color-text-muted);vertical-align:middle}.task-diagram-wrap{overflow-x:auto}.task-diagram{width:100%;min-height:200px}.diagram-node{fill:var(--color-accent-soft);stroke:var(--color-accent);stroke-width:1.5}.diagram-node-done{fill:var(--color-success-soft);stroke:var(--color-success)}.diagram-node-blocked{fill:var(--color-danger-soft);stroke:var(--color-danger)}.diagram-node-title{font-size:12px;font-weight:600;fill:var(--color-text)}.diagram-node-progress{font-size:11px;fill:var(--color-text-muted)}.diagram-edge{stroke:#94a3b8;stroke-width:1.5}.diagram-edge-blocked{stroke:var(--color-danger);stroke-dasharray:4 3}.faq-list{display:flex;flex-direction:column}.faq-item{border-bottom:1px solid var(--color-border)}.faq-item:last-child{border-bottom:none}.faq-question{width:100%;background:transparent;color:var(--color-text);border:none;padding:14px 4px;display:flex;align-items:center;justify-content:space-between;font-size:14px;font-weight:600;text-align:left;cursor:pointer}.faq-question:hover{background:transparent;color:var(--color-accent)}.faq-chevron{color:var(--color-text-muted);transition:transform .15s ease}.faq-chevron-open{transform:rotate(180deg)}.faq-answer{padding:0 4px 16px;font-size:13.5px;color:var(--color-text-muted);line-height:1.6}.ai-chat-fab{position:fixed;bottom:24px;right:24px;width:52px;height:52px;border-radius:50%;background:var(--color-accent);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);z-index:1100;padding:0}.ai-chat-fab:hover{background:var(--color-accent-hover)}.ai-chat-panel{position:fixed;bottom:88px;right:24px;width:320px;max-height:440px;background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;z-index:1100;overflow:hidden}.ai-chat-header{background:var(--color-accent);color:#fff;padding:12px 14px;display:flex;align-items:center;justify-content:space-between;font-size:14px;font-weight:600}.ai-chat-header small{font-weight:400;opacity:.8;font-size:11px}.ai-chat-header .modal-close{color:#fff}.ai-chat-messages{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px;min-height:200px}.ai-chat-bubble{background:var(--color-bg);border-radius:var(--radius-md);padding:8px 12px;font-size:13px;max-width:85%;align-self:flex-start;line-height:1.4}.ai-chat-bubble-user{background:var(--color-accent-soft);color:var(--color-accent);align-self:flex-end}.ai-chat-input{display:flex;gap:6px;padding:10px;border-top:1px solid var(--color-border)}.ai-chat-input input{flex:1}@media(max-width:480px){.ai-chat-panel{width:calc(100vw - 32px);right:16px}.ai-chat-fab{right:16px}}@media(max-width:860px){.menu-toggle{display:inline-flex;align-items:center;justify-content:center}.sidebar{position:fixed;top:0;left:0;height:100vh;z-index:950;transform:translate(-100%);transition:transform .2s ease;box-shadow:var(--shadow-lg)}.sidebar.open{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;inset:0;background:#10122173;z-index:940}.content{padding:20px 16px}.stat-grid,.chart-grid,.services-grid,.field-row{grid-template-columns:1fr}}
