:root{--navy: #0F2A44;--navy-dark: #081C2E;--navy-light: #1A3D5C;--slate: #1E2E3E;--orange: #C6923A;--orange-dark:#A87830;--blue: #1A4FBF;--blue-light: #EBF2FF;--green: #1A7A4A;--green-light:#D4F4E2;--amber: #C6923A;--amber-light:#FBF0DC;--red: #C0392B;--red-light: #FDECEA;--border: #E4E8EC;--text: #0F2A44;--muted: #64748B;--bg: #F4F6F8;--white: #FFFFFF;--sidebar-w: 260px;--font: "Segoe UI", Arial, Helvetica, system-ui, sans-serif;--font-brand: Arial, Helvetica, sans-serif;--radius: 10px;--shadow: 0 1px 3px rgba(15,42,68,.08), 0 1px 2px rgba(15,42,68,.05);--shadow-md: 0 4px 6px rgba(15,42,68,.08), 0 2px 4px rgba(15,42,68,.05);--shadow-lg: 0 8px 24px rgba(15,42,68,.1), 0 4px 6px rgba(15,42,68,.05)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:var(--font);color:var(--text);background:var(--bg)}a{text-decoration:none;color:inherit}button{cursor:pointer;font-family:var(--font)}input,select,textarea{font-family:var(--font)}.splash{position:fixed;inset:0;background:var(--navy);display:flex;align-items:center;justify-content:center;z-index:9999;transition:opacity .3s ease}.splash-inner{text-align:center;color:#fff}.splash-logo{font-size:48px;margin-bottom:12px}.splash-name{font-size:24px;font-weight:700;letter-spacing:-.5px;margin-bottom:24px}.splash-spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,.2);border-top-color:var(--orange);border-radius:50%;margin:0 auto;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--navy);color:#fff;display:flex;flex-direction:column;overflow:hidden;position:relative;z-index:100;transition:transform .25s ease}.sidebar-top{flex:1;overflow-y:auto;padding:0 0 8px}.sidebar-bottom{padding:12px 16px;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:8px}.sidebar-logo{display:flex;flex-direction:column;align-items:flex-start;padding:18px 16px 14px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo-img{width:calc(var(--sidebar-w) - 32px)!important;max-width:calc(var(--sidebar-w) - 32px)!important;height:auto!important;max-height:70px!important;object-fit:contain!important;object-position:left center!important;display:block!important}.sidebar-company-block{margin-top:14px;width:100%}.sidebar-company-name{font-size:13px;font-weight:700;color:#ffffffe6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.sidebar-company-tag{font-size:11px;color:#ffffff73;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logo-mark{font-size:24px;flex-shrink:0}.logo-text{display:flex;flex-direction:column;min-width:0}.logo-company{font-size:13px;font-weight:700;color:#ffffffe6}.logo-tag{font-size:11px;color:#ffffff73}.project-selector{padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.08)}.project-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#fff6;margin-bottom:6px}.project-select-row{display:flex;gap:6px;align-items:center}.project-select{flex:1;background:#ffffff14;color:#fff;border:1px solid rgba(255,255,255,.12);border-radius:6px;padding:6px 10px;font-size:13px;min-width:0}.project-select option{background:var(--navy);color:#fff}.sidebar-nav{padding:8px 0}.nav-section-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#ffffff4d;padding:8px 16px 4px}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 16px;font-size:13.5px;color:#ffffffbf;transition:background .15s,color .15s;cursor:pointer;border-left:3px solid transparent}.nav-item:hover{background:#ffffff0f;color:#fff}.nav-item.active{background:#f26a2126;color:#fff;border-left-color:var(--orange)}.nav-icon{font-size:16px;width:20px;text-align:center;flex-shrink:0}.nav-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sync-status{display:flex;align-items:center;gap:7px;font-size:12px;color:#ffffff80}.sync-dot{width:8px;height:8px;border-radius:50%;background:var(--muted);flex-shrink:0}.dot-ok{background:#4ade80}.dot-syncing{background:var(--amber);animation:pulse 1s infinite}.dot-offline,.dot-error{background:var(--red)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.bc-watermark{display:flex;align-items:center;padding:8px 16px 12px}.bc-wm-icon{display:none}.user-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.user-info{display:flex;flex-direction:column;min-width:0}.user-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:11px;color:#fff6;text-transform:capitalize}.sidebar-version{font-size:10px;color:#ffffff40;text-align:center}.main-content{flex:1;overflow-y:auto;background:var(--bg);min-width:0}#view-container{min-height:100%}.mobile-menu-btn{display:none;position:fixed;top:12px;left:12px;z-index:200;background:var(--navy);color:#fff;border:none;border-radius:6px;width:40px;height:40px;font-size:18px;align-items:center;justify-content:center;box-shadow:var(--shadow-md)}.auth-screen{min-height:100vh;background:var(--navy);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px}.auth-card{background:#fff;border-radius:12px;padding:32px;width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.auth-logo{text-align:center;margin-bottom:24px}.auth-logo-icon{display:block;font-size:36px;margin-bottom:8px}.auth-logo-name{display:block;font-size:22px;font-weight:800;color:var(--navy)}.auth-logo-tag{display:block;font-size:14px;font-weight:700;color:var(--orange);margin-top:2px}.auth-tabs{display:flex;border-bottom:2px solid var(--border);margin-bottom:20px}.auth-tab{flex:1;background:none;border:none;padding:10px;font-size:14px;font-weight:600;color:var(--muted);cursor:pointer;transition:color .15s}.auth-tab.active{color:var(--navy);border-bottom:2px solid var(--navy);margin-bottom:-2px}.auth-form{display:none}.auth-form.active{display:block}.auth-error{font-size:13px;color:var(--red);padding:8px 12px;background:var(--red-light);border-radius:6px;margin-bottom:12px}.auth-success{font-size:13px;color:var(--green);padding:8px 12px;background:var(--green-light);border-radius:6px;margin-bottom:12px}.auth-divider{text-align:center;color:var(--muted);font-size:13px;margin:16px 0;position:relative}.auth-divider:before{content:"";position:absolute;left:0;top:50%;width:100%;height:1px;background:var(--border);z-index:0}.auth-divider span{background:#fff;padding:0 12px;position:relative;z-index:1}.invite-row{display:flex;gap:8px}.invite-row input{flex:1}.auth-footer{color:#ffffff4d;font-size:12px;margin-top:20px}.onboarding-card{max-width:480px}.onboarding-title{font-size:20px;font-weight:700;color:var(--navy);margin-bottom:6px}.onboarding-sub{font-size:14px;color:var(--muted);margin-bottom:20px}.onboarding-section{margin-bottom:16px}.invite-notice{background:var(--blue-light);border:1px solid #c3d9ff;border-radius:8px;padding:12px 14px;font-size:14px;color:var(--navy)}.hidden{display:none!important}.field-group{margin-bottom:14px}.field-group label{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:5px}.field-group input,.field-group select,.field-group textarea{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:6px;font-size:14px;transition:border-color .15s;background:#fff;color:var(--text)}.field-group input:focus,.field-group select:focus,.field-group textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px #1a4fbf1a}.field-hint{font-size:12px;color:var(--muted);margin-top:4px;display:block}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.required{color:var(--red)}.btn-primary{background:var(--orange);color:#fff;border:none;padding:10px 20px;border-radius:6px;font-size:14px;font-weight:600;transition:background .15s;cursor:pointer}.btn-primary:hover{background:var(--orange-dark)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-full{width:100%}.btn-secondary{background:#fff;color:var(--navy);border:1px solid var(--border);padding:9px 18px;border-radius:6px;font-size:14px;font-weight:600;transition:background .15s,border-color .15s}.btn-secondary:hover{background:var(--bg);border-color:var(--navy)}.btn-link{background:none;border:none;color:var(--blue);font-size:13px;padding:6px 0;display:block;text-align:center;width:100%;margin-top:8px}.btn-link:hover{text-decoration:underline}.btn-icon{background:#ffffff1a;color:#fff;border:none;width:28px;height:28px;border-radius:5px;font-size:16px;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0}.btn-icon:hover{background:#fff3}.main-content .btn-icon{background:var(--border);color:var(--text)}.main-content .btn-icon:hover{background:var(--navy);color:#fff}.sign-out-btn{opacity:.6}.sign-out-btn:hover{opacity:1;background:#c0392b4d!important}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:#fff;border-radius:12px;width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border)}.modal-header h3{font-size:17px;font-weight:700;color:var(--navy)}.modal-close{background:none;border:none;font-size:18px;color:var(--muted);cursor:pointer;line-height:1}.modal-close:hover{color:var(--text)}.modal-body{flex:1;overflow-y:auto;padding:20px}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.view-header{background:#fff;border-bottom:1px solid var(--border);padding:16px 24px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10}.view-header h1{font-size:20px;font-weight:700;color:var(--navy)}.view-body{padding:24px}.view-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;color:var(--muted);gap:8px}.view-placeholder h2{font-size:24px;color:var(--navy);text-transform:capitalize}.card{background:#fff;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden}.card-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:nowrap;overflow:hidden}.card-title{font-size:15px;font-weight:700;color:var(--navy);white-space:nowrap;flex-shrink:0}.card-body{padding:18px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13px}thead th{background:var(--navy);color:#fff;padding:9px 12px;text-align:left;font-size:12px;font-weight:600;white-space:nowrap}tbody td{padding:8px 12px;border-bottom:1px solid var(--border);vertical-align:middle}tbody tr:nth-child(2n) td{background:var(--bg)}tbody tr:hover td{background:var(--blue-light)}.badge{display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;border-radius:12px}.badge-blue{background:var(--blue-light);color:var(--blue)}.badge-green{background:var(--green-light);color:var(--green)}.badge-amber{background:var(--amber-light);color:var(--amber)}.badge-red{background:var(--red-light);color:var(--red)}.badge-navy{background:var(--navy);color:#fff}.badge-orange{background:#fee8d6;color:var(--orange)}.empty-state{text-align:center;padding:48px 24px;color:var(--muted)}.empty-state-icon{font-size:40px;margin-bottom:12px}.empty-state h3{font-size:17px;font-weight:600;color:var(--text);margin-bottom:6px}.empty-state p{font-size:14px;margin-bottom:16px}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.stat-card{background:#fff;border-radius:var(--radius);border:1px solid var(--border);padding:18px;box-shadow:var(--shadow)}.stat-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:6px}.stat-value{font-size:26px;font-weight:800;color:var(--navy)}.stat-sub{font-size:12px;color:var(--muted);margin-top:4px}.mode-badge-basic{background:var(--amber-light);color:var(--amber)}.mode-badge-detailed{background:var(--blue-light);color:var(--blue)}@media (max-width: 768px){.sidebar{position:fixed;top:0;left:0;bottom:0;transform:translate(-100%)}.sidebar.open{transform:translate(0);box-shadow:var(--shadow-lg)}.mobile-menu-btn{display:flex}.main-content{padding-top:0}.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}.field-row{grid-template-columns:1fr}}@media (max-width: 480px){.auth-card{padding:24px 16px}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.view-body{padding:16px}}.auth-logo-hero{text-align:center;padding:24px 0 22px;border-bottom:1px solid var(--border);margin-bottom:22px}.auth-hero-img{width:92%!important;max-width:380px!important;height:auto!important;display:block;margin:0 auto}.auth-tagline{text-align:center;font-size:13px;font-weight:700;color:var(--orange);text-transform:uppercase;letter-spacing:.08em;margin-bottom:20px}.auth-watermark{margin-top:24px;display:flex;flex-direction:column;align-items:center;gap:6px;opacity:.4}.auth-wm-img{max-width:160px;width:80%;height:auto}.bc-watermark-img{width:calc(var(--sidebar-w) - 40px);max-width:calc(var(--sidebar-w) - 40px);height:auto;max-height:32px;object-fit:contain;object-position:left center;display:block;opacity:.5}.customer-logo-img{width:calc(var(--sidebar-w) - 32px);max-width:calc(var(--sidebar-w) - 32px);max-height:56px;height:auto;object-fit:contain;object-position:left center;display:block;margin-bottom:18px}.auth-wm-img{opacity:.6}.mode-toggle{display:flex;border:1px solid var(--border);border-radius:6px;overflow:hidden}.mode-btn{padding:6px 14px;font-size:13px;font-weight:600;border:none;background:#fff;color:var(--muted);cursor:pointer;transition:background .15s,color .15s}.mode-btn.active{background:var(--navy);color:#fff}.mode-btn:hover:not(.active){background:var(--bg)}.inline-input{border:none;background:transparent;padding:3px 4px;font-family:var(--font);font-size:13px;color:var(--text);border-bottom:1px solid transparent;transition:border-color .15s;border-radius:0}.inline-input:hover{border-bottom-color:var(--border)}.inline-input:focus{outline:none;border-bottom:2px solid var(--blue);background:#1a4fbf0a}.inline-select{border:1px solid var(--border);border-radius:4px;padding:3px 6px;font-family:var(--font);font-size:12px;background:#fff;color:var(--text);cursor:pointer}.inline-select:focus{outline:none;border-color:var(--blue)}.phase-header-row td{padding:6px 12px!important}.task-row:hover td{background:var(--blue-light)!important}.mode-toggle-sidebar{display:flex;margin-top:8px;border-radius:5px;overflow:hidden;border:1px solid rgba(255,255,255,.15)}.mode-sidebar-btn{flex:1;padding:5px 6px;font-size:11px;font-weight:600;border:none;background:#ffffff0d;color:#ffffff80;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.mode-sidebar-btn:hover{background:#ffffff1a;color:#fffc}.mode-sidebar-btn.active{background:var(--orange);color:#fff}.doc-tabs{display:flex;border-bottom:1px solid var(--border);overflow-x:auto;padding:0 4px}.doc-tab{padding:10px 16px;background:none;border:none;border-bottom:2px solid transparent;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s;display:flex;align-items:center;gap:6px}.doc-tab:hover{color:var(--text)}.doc-tab.active{color:var(--navy);border-bottom-color:var(--navy)}.doc-tab-count{background:var(--border);color:var(--muted);font-size:11px;padding:1px 6px;border-radius:10px;font-weight:700}.doc-tab.active .doc-tab-count{background:var(--navy);color:#fff}.doc-grid{display:flex;flex-direction:column;gap:8px}.doc-card{display:flex;align-items:flex-start;gap:12px;padding:12px;border:1px solid var(--border);border-radius:8px;transition:background .15s}.doc-card:hover{background:var(--bg)}.doc-card-icon{font-size:24px;flex-shrink:0;margin-top:2px}.doc-card-info{flex:1;min-width:0}.doc-card-name{font-size:14px;font-weight:600;color:var(--text)}.doc-card-path{font-size:12px;color:var(--blue);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.doc-card-notes{font-size:12px;color:var(--muted);margin-top:3px}.doc-card-date{font-size:11px;color:var(--muted);margin-top:4px}.doc-card-actions{display:flex;flex-direction:column;gap:4px;flex-shrink:0}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}.photo-card{cursor:pointer}.photo-card:hover .photo-thumb{opacity:.9}.support-article{border:1px solid var(--border);border-radius:6px;margin-bottom:8px;overflow:hidden;cursor:pointer}.support-article-title{padding:10px 14px;font-size:14px;font-weight:600;color:var(--navy);background:var(--bg);display:flex;justify-content:space-between}.support-article-title:after{content:"›";color:var(--muted)}.support-article.expanded .support-article-title:after{content:"⌄"}.support-article-body{display:none;padding:12px 14px;font-size:13px;line-height:1.7;color:var(--text);border-top:1px solid var(--border)}.support-article.expanded .support-article-body{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}th{position:relative;user-select:none}.resize-handle{position:absolute;right:0;top:0;bottom:0;width:5px;cursor:col-resize;background:transparent;z-index:10}.resize-handle:hover,.resize-handle.dragging{background:#1a4fbf59}.group-header td{background:#0f2a44!important;color:#fff!important;font-weight:600;font-size:12px;padding:7px 11px;letter-spacing:.03em}.group-header td:first-child{color:#ffffff80!important;font-family:monospace}.subtotal-row td{background:#f1f5f9;font-weight:600;font-size:12px;border-top:1.5px solid var(--border);color:#475569}.total-row td{background:#0f2a44;color:#fff;font-weight:700;border-top:2px solid var(--border)}.total-row td:first-child{color:#ffffff80}.var-pos{color:var(--green);font-weight:700}.var-neg{color:var(--red);font-weight:700}.pct-wrap{display:flex;align-items:center;gap:6px;justify-content:flex-end}.pct-bg{width:50px;height:5px;background:var(--border);border-radius:3px;overflow:hidden}.pct-fill{height:100%;border-radius:3px}.bar-track{position:relative;height:28px;width:100%;min-width:260px}.month-header-row{display:flex;width:100%}.month-slot{font-size:10px;font-weight:600;color:#ffffffbf;text-align:center;overflow:hidden;white-space:nowrap;border-right:1px solid rgba(255,255,255,.15);padding:0 2px;line-height:24px;height:24px}.today-line{position:absolute;top:0;bottom:0;width:2px;background:#e53e3e;z-index:3;pointer-events:none;border-radius:1px}.today-label{position:absolute;top:-10px;font-size:9px;font-weight:700;color:#e53e3e;white-space:nowrap;line-height:1}.bar-proj{position:absolute;top:3px;height:9px;border-radius:3px;background:#bfdbfe}.bar-act{position:absolute;top:15px;height:9px;border-radius:3px}.bar-ok{background:var(--blue)}.bar-over{background:var(--red)}.bar-prog{background:var(--amber)}.pf-table{width:100%;border-collapse:collapse;font-size:13px}.pf-table thead th{background:var(--navy);color:#fff;padding:8px 10px;text-align:right;font-size:11px;font-weight:600;white-space:nowrap;position:relative}.pf-table thead th.col-left{text-align:left}.pf-table td{padding:6px 10px;border-bottom:1px solid var(--border);text-align:right;vertical-align:middle;overflow:hidden;text-overflow:ellipsis}.pf-table td.col-left{text-align:left}.pf-table tr:hover:not(.pf-total):not(.pf-hdr) td{background:var(--bg)}.pf-hdr td{background:#2c3e5a;color:#ffffffd9;font-size:11px;font-weight:700;padding:5px 10px;text-transform:uppercase;letter-spacing:.06em}.pf-total td{background:var(--bg);font-weight:700;border-top:2px solid var(--border)}.tdcalc{color:var(--text);background:var(--bg)!important}.tdgood{color:var(--green)!important}.tdbad{color:var(--red)!important}.tdinp{border:none;background:transparent;width:100%;font-family:var(--font);font-size:13px;color:var(--text);padding:2px 4px;text-align:right}.tdinp:focus{outline:1px solid var(--blue);border-radius:3px}.tdinp.left{text-align:left}.app-page-footer{display:flex;align-items:center;justify-content:center;padding:24px 0 20px;margin-top:24px;border-top:1px solid var(--border);opacity:.6;transition:opacity .2s}.app-page-footer:hover{opacity:.85}.page-footer-logo{height:44px;width:auto;object-fit:contain}
