@import "https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Lato:ital,wght@0,100;0,300;0,400;0,700;0,900;1,100;1,300;1,400;1,700;1,900&family=Playfair+Display:ital,wght@0,400..900;1,400..900&family=SN+Pro:ital,wght@0,200..900;1,200..900&display=swap";@import "https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800&family=DM+Sans:wght@300;400;500;600&display=swap";@import "https://fonts.googleapis.com/css2?family=Outfit:wght@400;600;700;800&family=DM+Sans:wght@300;400;500;600&display=swap";@import "https://fonts.googleapis.com/css2?family=Outfit:wght@400;600;700;800&family=DM+Sans:wght@300;400;500;600&display=swap";*{box-sizing:border-box;margin:0;padding:0;font-family:Outfit,sans-serif!important}:root{--sidebar-bg:#fff;--sidebar-border:#e8eaed;--sidebar-width:270px;--sidebar-collapsed-width:72px;--text-primary:#1c1e21;--text-secondary:#65676b;--text-muted:#90949c;--accent:#1a73e8;--accent-hover:#1557b0;--accent-soft:#e8f0fe;--accent-text:#1a73e8;--surface:#f0f2f5;--surface-hover:#e4e6eb;--surface-active:#dce8fb;--danger:#e53935;--danger-soft:#fdecea;--danger-hover:#c62828;--avatar-bg:linear-gradient(135deg, #1a73e8, #0d47a1);--logo-bg:linear-gradient(135deg, #1a73e8, #1557b0);--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000d;--shadow-md:0 4px 16px #0000001a;--shadow-lg:0 12px 40px #00000026;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-full:50%;--transition:.22s cubic-bezier(.4, 0, .2, 1);--transition-slow:.35s cubic-bezier(.4, 0, .2, 1);--font:"DM Sans", "Segoe UI", sans-serif}body.dark-theme{--sidebar-bg:#1a1d24;--sidebar-border:#2a2d35;--text-primary:#e8eaed;--text-secondary:#9aa0ab;--text-muted:#5f6671;--accent:#4d9ef7;--accent-hover:#3b87e3;--accent-soft:#1e2f4a;--accent-text:#6eb3fb;--surface:#22262f;--surface-hover:#2a2f3a;--surface-active:#1e2f4a;--danger:#ef5350;--danger-soft:#2a1919;--danger-hover:#c62828;--avatar-bg:linear-gradient(135deg, #4d9ef7, #2471c8);--logo-bg:linear-gradient(135deg, #4d9ef7, #2471c8);--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 12px 40px #00000080;color:var(--text-primary);background:#13161c}*{box-sizing:border-box}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);transition:width var(--transition-slow), transform var(--transition-slow), background var(--transition);z-index:1000;font-family:var(--font);box-shadow:var(--shadow-sm);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar-overlay{z-index:999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;animation:.25s fadeOverlay;display:none;position:fixed;inset:0}.sidebar-overlay.visible{display:block}@keyframes fadeOverlay{0%{opacity:0}to{opacity:1}}.sidebar-header{border-bottom:1px solid var(--sidebar-border);flex-shrink:0;justify-content:space-between;align-items:center;gap:10px;min-height:68px;padding:18px 16px;display:flex}.logo-container{flex:1;align-items:center;gap:10px;min-width:0;display:flex;overflow:hidden}.logo-img{object-fit:contain;border-radius:var(--radius-sm);width:140px;height:60px;transition:opacity var(--transition);flex-shrink:0}.logo-mini-badge{background:var(--logo-bg);color:#fff;border-radius:var(--radius-md);letter-spacing:-.5px;width:38px;height:38px;box-shadow:var(--shadow-sm);flex-shrink:0;justify-content:center;align-items:center;font-size:15px;font-weight:800;display:flex}.logo-text{flex-direction:column;min-width:0;line-height:1.2;display:flex}.brand-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:700;overflow:hidden}.brand-sub{color:var(--text-muted);white-space:nowrap;font-size:10.5px}.sidebar.collapsed .logo-img,.sidebar.collapsed .logo-text{display:none}.toggle-btn{border:1px solid var(--sidebar-border);background:var(--surface);width:34px;height:34px;color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);flex-shrink:0;justify-content:center;align-items:center;display:flex}.toggle-btn:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent);transform:scale(1.05)}.mobile-toggle{z-index:1100;background:var(--sidebar-bg);border:1px solid var(--sidebar-border);border-radius:var(--radius-md);cursor:pointer;width:42px;height:42px;color:var(--text-primary);box-shadow:var(--shadow-md);transition:all var(--transition);justify-content:center;align-items:center;display:none;position:fixed;bottom:14px;left:14px}.mobile-toggle:hover{background:var(--accent-soft);color:var(--accent)}.user-profile{border-bottom:1px solid var(--sidebar-border);flex-shrink:0;padding:14px 16px}.user-avatar{border-radius:var(--radius-lg);transition:background var(--transition);cursor:default;align-items:center;gap:12px;padding:8px 10px;display:flex}.user-avatar:hover{background:var(--surface)}.avatar{background:var(--avatar-bg);color:#fff;border-radius:var(--radius-full);letter-spacing:.5px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:14px;font-weight:700;display:flex;box-shadow:0 2px 8px #1a73e859}.user-info{flex-direction:column;animation:.2s slideIn;display:flex;overflow:hidden}.user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;letter-spacing:.1px;font-size:13.5px;font-weight:600;overflow:hidden}.user-role{color:var(--accent-text);margin-top:1px;font-size:11.5px;font-weight:500}.sidebar-nav{flex:1;padding:10px 0;overflow:hidden auto}.sidebar-nav::-webkit-scrollbar{width:3px}.sidebar-nav::-webkit-scrollbar-track{background:0 0}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--sidebar-border);border-radius:4px}.nav-section-label{text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);transition:opacity var(--transition);padding:12px 20px 6px;font-size:10px;font-weight:700}.sidebar.collapsed .nav-section-label{opacity:0;pointer-events:none;height:0;padding:0}.menu-section{margin-bottom:2px;padding:0 10px}.menu-item{width:100%;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);text-align:left;border-radius:var(--radius-md);font-size:13.5px;font-weight:500;font-family:var(--font);background:0 0;border:none;align-items:center;gap:12px;padding:11px 12px;display:flex;position:relative}.menu-item:hover{background:var(--surface-hover);color:var(--text-primary)}.menu-item.active{background:var(--accent-soft);color:var(--accent-text);font-weight:600}.menu-item.active .menu-icon{color:var(--accent)}.menu-item.has-sub.open{background:var(--surface);color:var(--text-primary)}.menu-icon{width:22px;min-width:22px;color:inherit;transition:color var(--transition);justify-content:center;align-items:center;display:flex}.menu-title{letter-spacing:.1px;white-space:nowrap;text-overflow:ellipsis;flex:1;animation:.18s slideIn;overflow:hidden}.dropdown-arrow{color:var(--text-muted);transition:transform var(--transition);flex-shrink:0}.dropdown-arrow.open{transform:rotate(180deg)}.submenu{opacity:0;max-height:0;padding:0 0 0 8px;transition:max-height .3s,opacity .25s;overflow:hidden}.submenu.open{opacity:1;max-height:400px;padding-top:2px;padding-bottom:4px}.submenu-item{width:100%;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition);font-size:13px;font-family:var(--font);text-align:left;background:0 0;border:none;align-items:center;gap:10px;margin-top:8px;margin-bottom:1px;padding:9px 12px 9px 16px;font-weight:400;display:flex;position:relative}.submenu-item:before{content:"";background:var(--accent);width:2px;height:0;transition:height var(--transition);border-radius:2px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.submenu-item:hover{background:var(--surface-hover);color:var(--text-primary)}.submenu-item:hover:before{height:60%}.submenu-item.active{background:var(--accent-soft);color:var(--accent-text);font-weight:500}.submenu-item.active:before{height:70%}.submenu-icon{justify-content:center;align-items:center;width:18px;min-width:18px;display:flex}.sidebar.collapsed .menu-item,.sidebar.collapsed .menu-header{justify-content:center;padding:11px}.sidebar.collapsed .menu-title,.sidebar.collapsed .dropdown-arrow,.sidebar.collapsed .submenu,.sidebar.collapsed .nav-section-label,.sidebar.collapsed .user-info,.sidebar.collapsed .theme-text,.sidebar.collapsed .logout-text{display:none}.tooltip-wrapper{position:relative}.sidebar.collapsed .tooltip-wrapper:hover .tooltip-label{opacity:1;pointer-events:auto;transform:translate(0)}.tooltip-label{background:var(--text-primary);color:var(--sidebar-bg);border-radius:var(--radius-sm);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity var(--transition), transform var(--transition);z-index:2000;box-shadow:var(--shadow-md);padding:5px 10px;font-size:12px;font-weight:500;position:absolute;top:50%;left:calc(100% + 12px);transform:translateY(-50%)translate(-8px)}.tooltip-label:before{content:"";border:5px solid #0000;border-right-color:var(--text-primary);position:absolute;top:50%;right:100%;transform:translateY(-50%)}.sidebar-footer{border-top:1px solid var(--sidebar-border);flex-direction:column;flex-shrink:0;gap:6px;padding:12px 10px;display:flex}.theme-toggle,.logout-btn{width:100%;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition);font-size:13.5px;font-weight:500;font-family:var(--font);text-align:left;background:0 0;border:none;align-items:center;gap:12px;padding:10px 120px;display:flex}.sidebar.collapsed .theme-toggle,.sidebar.collapsed .logout-btn{justify-content:center;padding:11px}.theme-toggle:hover{background:var(--surface-hover);color:var(--text-primary)}.theme-icon,.logout-icon{justify-content:center;align-items:center;width:22px;min-width:22px;display:flex}.logout-btn{color:var(--danger)}.logout-btn:hover{background:var(--danger-soft);color:var(--danger)}.logout-modal-overlay{z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;padding:20px;animation:.2s fadeOverlay;display:flex;position:fixed;inset:0}.logout-modal{background:var(--sidebar-bg);border-radius:var(--radius-lg);text-align:center;width:100%;max-width:340px;box-shadow:var(--shadow-lg);border:1px solid var(--sidebar-border);padding:32px 28px 28px;animation:.25s cubic-bezier(.175,.885,.32,1.275) popIn}.logout-modal-icon{background:var(--danger-soft);border-radius:var(--radius-full);width:52px;height:52px;color:var(--danger);justify-content:center;align-items:center;margin:0 auto 16px;display:flex}.logout-modal h3{color:var(--text-primary);font-size:18px;font-weight:700;font-family:var(--font);margin:0 0 8px}.logout-modal p{color:var(--text-secondary);font-size:13.5px;font-family:var(--font);margin:0 0 24px;line-height:1.5}.logout-modal-actions{gap:10px;display:flex}.cancel-btn{border-radius:var(--radius-md);border:1px solid var(--sidebar-border);background:var(--surface);color:var(--text-primary);cursor:pointer;font-size:13.5px;font-weight:500;font-family:var(--font);transition:all var(--transition);flex:1;padding:11px}.cancel-btn:hover{background:var(--surface-hover)}.confirm-btn{border-radius:var(--radius-md);background:var(--danger);color:#fff;cursor:pointer;font-size:13.5px;font-weight:600;font-family:var(--font);transition:all var(--transition);border:none;flex:1;padding:11px;box-shadow:0 2px 8px #e5393559}.confirm-btn:hover{background:var(--danger-hover);transform:translateY(-1px);box-shadow:0 4px 12px #e5393573}@keyframes slideIn{0%{opacity:0;transform:translate(-6px)}to{opacity:1;transform:translate(0)}}@keyframes popIn{0%{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}.main-content{margin-left:var(--sidebar-width);background:var(--surface);min-height:100vh;transition:margin-left var(--transition-slow), background var(--transition)}.sidebar.collapsed~.main-content{margin-left:var(--sidebar-collapsed-width)}@media (width<=768px){.mobile-toggle{display:flex}.sidebar{box-shadow:none;transform:translate(-100%);width:270px!important}.sidebar.mobile-open{box-shadow:var(--shadow-lg);transform:translate(0)}.main-content{margin-left:0!important}.sidebar.collapsed{transform:translate(-100%)}.toggle-btn{display:none}}@media (width<=480px){.logout-modal{padding:24px 20px 20px}}.app-root *,.app-root :before,.app-root :after{box-sizing:border-box;margin:0;padding:0}.app-root{color:#1a1714;background:#f5f2ed;min-height:100vh;font-family:DM Sans,sans-serif}.dash-wrap{margin:0 auto;padding:0 0 60px}.dash-header{z-index:50;background:#fff;border-bottom:1px solid #ede9e3;padding:24px 24px 0;position:sticky;top:0;box-shadow:0 1px 8px #1a17140f}.dash-header-content{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:28px;display:flex}.dash-logo{align-items:center;gap:12px;display:flex}.dash-logo-icon{color:#fff;background:linear-gradient(135deg,#e8900a,#c96d00);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-family:Outfit,sans-serif;font-size:20px;font-weight:800;display:flex;box-shadow:0 4px 14px #e8900a59}.dash-title{color:#1a1714;letter-spacing:-.5px;font-family:Outfit,sans-serif;font-size:22px;font-weight:800;line-height:1.1}.dash-sub{color:#a8a29e;margin-top:2px;font-size:12px}.dash-stats{scrollbar-width:none;border-top:1px solid #f0ece6;gap:0;margin:0 -24px;padding:0 24px;display:flex;overflow-x:auto}.dash-stats::-webkit-scrollbar{display:none}.dash-stat{border-right:1px solid #f0ece6;flex-shrink:0;align-items:center;gap:10px;min-width:100px;margin-right:20px;padding:14px 20px 14px 0;display:flex}.dash-stat:last-child{border-right:none}.dash-stat-icon{border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.dash-stat-val{color:#1a1714;font-family:Outfit,sans-serif;font-size:20px;font-weight:800;line-height:1}.dash-stat-label{color:#a8a29e;white-space:nowrap;margin-top:2px;font-size:10.5px;font-weight:500}.btn-new-project{color:#fff;cursor:pointer;white-space:nowrap;background:#e8900a;border:none;border-radius:10px;flex-shrink:0;align-items:center;gap:7px;padding:11px 20px;font-family:DM Sans,sans-serif;font-size:13.5px;font-weight:600;transition:background .18s,transform .18s,box-shadow .18s;display:flex;box-shadow:0 3px 12px #e8900a59}.btn-new-project:hover{background:#cf7e08;transform:translateY(-1px);box-shadow:0 5px 18px #e8900a73}.dash-search-wrap{flex-wrap:wrap;align-items:center;gap:14px;padding:20px 24px 12px;display:flex}.dash-search-box{background:#fff;border:1.5px solid #ede9e3;border-radius:10px;flex:1;align-items:center;gap:10px;min-width:200px;padding:10px 14px;transition:border-color .18s,box-shadow .18s;display:flex}.dash-search-box:focus-within{border-color:#e8900a;box-shadow:0 0 0 3px #e8900a1a}.dash-search-icon{color:#a8a29e;flex-shrink:0}.dash-search-input{color:#1a1714;background:0 0;border:none;outline:none;flex:1;font-family:DM Sans,sans-serif;font-size:13.5px}.dash-search-input::placeholder{color:#c4bfb9}.dash-count{color:#a8a29e;white-space:nowrap;font-size:12px;font-weight:500}.proj-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;padding:8px 24px 0;display:grid}.proj-card{background:#fff;border:1px solid #ede9e3;border-radius:16px;flex-direction:column;gap:0;padding:20px;transition:transform .2s,box-shadow .2s;animation:.25s cardIn;display:flex;box-shadow:0 2px 10px #1a17140f}.proj-card:hover{transform:translateY(-3px);box-shadow:0 8px 28px #1a17141a}@keyframes cardIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.proj-card-top{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.proj-card-icon{color:#e8900a;background:#fff7ed;border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.status-badge{letter-spacing:.3px;border-radius:20px;padding:4px 10px;font-size:10.5px;font-weight:700}.proj-card-name{color:#1a1714;letter-spacing:-.3px;white-space:nowrap;text-overflow:ellipsis;margin-bottom:10px;font-family:Outfit,sans-serif;font-size:16px;font-weight:700;overflow:hidden}.proj-card-meta{flex-direction:column;gap:5px;margin-bottom:16px;display:flex}.proj-card-meta-row{color:#a8a29e;align-items:center;gap:6px;font-size:12px;display:flex}.proj-card-value-row{justify-content:space-between;align-items:flex-end;margin-bottom:10px;display:flex}.proj-card-val-label{text-transform:uppercase;letter-spacing:.6px;color:#c4bfb9;margin-bottom:3px;font-size:10.5px;font-weight:600}.proj-card-val-amount{color:#e8900a;font-family:Outfit,sans-serif;font-size:18px;font-weight:800}.proj-card-val-received{color:#16a34a;font-family:Outfit,sans-serif;font-size:16px;font-weight:700}.proj-card-bar-wrap{align-items:center;gap:8px;margin-bottom:16px;display:flex}.proj-card-bar-track{background:#f5f2ed;border-radius:10px;flex:1;height:6px;overflow:hidden}.proj-card-bar-fill{background:linear-gradient(90deg,#e8900a,#f5c26b);border-radius:10px;height:100%;transition:width .5s}.proj-card-bar-pct{color:#e8900a;text-align:right;flex-shrink:0;min-width:32px;font-family:Outfit,sans-serif;font-size:12px;font-weight:700}.proj-card-actions{gap:8px;margin-top:4px;display:flex}.proj-card-btn-view{color:#fff;cursor:pointer;background:#e8900a;border:none;border-radius:9px;flex:1;justify-content:center;align-items:center;gap:7px;padding:10px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;transition:background .18s,transform .18s;display:flex}.proj-card-btn-view:hover{background:#cf7e08;transform:translateY(-1px)}.proj-card-btn-del{color:#dc2626;cursor:pointer;background:#fef2f2;border:1px solid #fecaca;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;transition:background .18s;display:flex}.proj-card-btn-del:hover{background:#fee2e2}.dash-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:80px 24px;display:flex}.dash-empty-icon{color:#e8900a;background:#fff7ed;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin-bottom:16px;display:flex}.dash-empty-title{color:#1a1714;margin-bottom:6px;font-family:Outfit,sans-serif;font-size:20px;font-weight:700}.dash-empty-sub{color:#a8a29e;font-size:13.5px}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0a08068c;justify-content:center;align-items:center;padding:16px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-box{background:#fff;border-radius:20px;flex-direction:column;width:100%;max-width:540px;max-height:90vh;animation:.25s cubic-bezier(.175,.885,.32,1.275) popUp;display:flex;overflow:hidden;box-shadow:0 20px 60px #0a080640}@keyframes popUp{0%{opacity:0;transform:scale(.92)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{border-bottom:1px solid #f0ece6;flex-shrink:0;align-items:flex-start;gap:13px;padding:22px 22px 18px;display:flex}.modal-header-icon{color:#e8900a;background:#fff7ed;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.modal-title{color:#1a1714;letter-spacing:-.3px;font-family:Outfit,sans-serif;font-size:19px;font-weight:700}.modal-sub{color:#a8a29e;margin-top:2px;font-size:12.5px}.modal-close{cursor:pointer;color:#6b6560;background:#f5f2ed;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;margin-left:auto;transition:background .18s;display:flex}.modal-close:hover{background:#ede9e3}.modal-body{flex:1;padding:20px 22px;overflow-y:auto}.modal-footer{border-top:1px solid #f0ece6;flex-shrink:0;gap:10px;padding:16px 22px 20px;display:flex}.btn-cancel{color:#6b6560;cursor:pointer;background:#f5f2ed;border:1px solid #ede9e3;border-radius:10px;flex:1;padding:12px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;transition:background .18s}.btn-cancel:hover{background:#ede9e3}.btn-save{color:#fff;cursor:pointer;background:#e8900a;border:none;border-radius:10px;flex:2;justify-content:center;align-items:center;gap:8px;padding:12px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:600;transition:background .18s,transform .18s;display:flex;box-shadow:0 3px 12px #e8900a4d}.btn-save:hover{background:#cf7e08;transform:translateY(-1px)}.form-grid{grid-template-columns:1fr 1fr;gap:13px;display:grid}.form-field{flex-direction:column;gap:6px;display:flex}.form-field.form-field-full{grid-column:1/-1}.form-label{text-transform:uppercase;letter-spacing:.9px;color:#a8a29e;font-size:11px;font-weight:700}.form-input,.form-select,.form-textarea{color:#1a1714;appearance:none;background:#faf8f5;border:1.5px solid #ede9e3;border-radius:9px;outline:none;width:100%;padding:11px 13px;font-family:DM Sans,sans-serif;font-size:13.5px;transition:border-color .18s,box-shadow .18s,background .18s}.form-input:focus,.form-select:focus,.form-textarea:focus{background:#fff;border-color:#e8900a;box-shadow:0 0 0 3px #e8900a1a}.form-input::placeholder,.form-textarea::placeholder{color:#c4bfb9}.form-textarea{resize:vertical;min-height:80px;line-height:1.55}.form-select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23a8a29e' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.input-prefix-wrap{align-items:center;display:flex;position:relative}.input-prefix{color:#6b6560;pointer-events:none;z-index:1;font-size:14px;font-weight:600;position:absolute;left:12px}.input-with-prefix{padding-left:26px}.detail-wrap{background:#f5f2ed;min-height:100vh}.detail-header{z-index:50;background:#fff;border-bottom:1px solid #ede9e3;position:sticky;top:0;box-shadow:0 2px 12px #1a171412}.detail-header-top{justify-content:space-between;align-items:center;gap:12px;padding:25px 20px 12px;display:flex}.back-btn{color:#6b6560;cursor:pointer;background:#f5f2ed;border:1px solid #ede9e3;border-radius:9px;align-items:center;gap:7px;padding:8px 14px 8px 10px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;transition:background .18s,color .18s;display:flex}.back-btn:hover{color:#1a1714;background:#ede9e3}.detail-header-main{align-items:center;gap:14px;padding:0 20px 14px;display:flex}.detail-container{gap:20px;display:flex}.detail-header-icon{color:#fff;background:linear-gradient(135deg,#e8900a,#c96d00);border-radius:13px;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;display:flex;box-shadow:0 4px 14px #e8900a59}.detail-title{color:#1a1714;letter-spacing:-.4px;white-space:nowrap;text-overflow:ellipsis;font-family:Outfit,sans-serif;font-size:20px;font-weight:800;overflow:hidden}.detail-sub{color:#a8a29e;margin-top:2px;font-size:12.5px}.detail-strip{scrollbar-width:none;border-top:1px solid #f0ece6;gap:0;padding:0 20px;display:flex;overflow-x:auto}.detail-strip::-webkit-scrollbar{display:none}.detail-strip-cell{border-right:1px solid #f0ece6;flex-direction:column;flex-shrink:0;align-items:center;gap:3px;min-width:100px;padding:12px 18px;display:flex}.detail-strip-cell:last-child{border-right:none}.detail-strip-label{text-transform:uppercase;letter-spacing:.8px;color:#c4bfb9;font-size:9.5px;font-weight:600}.detail-strip-val{font-family:Outfit,sans-serif;font-size:15px;font-weight:800}.detail-tabbar{scrollbar-width:none;border-top:1px solid #f0ece6;gap:2px;padding:0 16px;display:flex;overflow-x:auto}.detail-tabbar::-webkit-scrollbar{display:none}.detail-tab{color:#a8a29e;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2.5px solid #0000;flex-shrink:0;align-items:center;gap:6px;padding:12px 16px 13px;font-family:DM Sans,sans-serif;font-size:12.5px;font-weight:500;transition:color .18s,border-color .18s;display:flex}.detail-tab:hover{color:#e8900a}.detail-tab.detail-tab-active{color:#e8900a;border-bottom-color:#e8900a;font-weight:600}.detail-content{max-width:1000px;margin:0 auto;padding:20px 18px 60px}.tab-anim{gap:20px;animation:.2s tabIn;display:flex}@keyframes tabIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.detail-card{background:#fff;border:1px solid #ede9e3;border-radius:16px;margin-bottom:14px;padding:18px 18px 20px;box-shadow:0 1px 6px #1a17140d}.detail-card-header{text-transform:uppercase;letter-spacing:1.1px;color:#a8a29e;align-items:center;gap:8px;margin-bottom:16px;font-family:Outfit,sans-serif;font-size:11px;font-weight:700;display:flex}.detail-card-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.btn-add-entry{color:#fff;cursor:pointer;background:#e8900a;border:none;border-radius:9px;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:15px;padding:12.5px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:600;transition:background .18s,transform .18s,box-shadow .18s;display:flex;box-shadow:0 2px 10px #e8900a4d}.btn-add-entry:hover{background:#cf7e08;transform:translateY(-1px);box-shadow:0 4px 16px #e8900a66}.btn-add-entry.green{background:#16a34a;box-shadow:0 2px 10px #16a34a4d}.btn-add-entry.green:hover{background:#15803d;box-shadow:0 4px 16px #16a34a66}.expense-pills{flex-wrap:wrap;gap:6px;margin-bottom:14px;display:flex}.expense-pill{color:#6b6560;cursor:pointer;background:#fff;border:1.5px solid #ede9e3;border-radius:30px;padding:8px 20px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;transition:all .18s}.expense-pill:hover{color:#e8900a;background:#fff7ed;border-color:#e8900a}.expense-pill-active{color:#fff;background:#e8900a;border-color:#e8900a;font-weight:600;box-shadow:0 2px 8px #e8900a59}.entry-list{flex-direction:column;gap:8px;display:flex}.entry-count{color:#a8a29e;text-transform:none;letter-spacing:0;background:#f5f2ed;border-radius:20px;margin-left:auto;padding:2px 8px;font-family:DM Sans,sans-serif;font-size:11px;font-weight:600}.entry-row{background:#faf8f5;border:1px solid #ede9e3;border-radius:11px;align-items:flex-start;gap:12px;padding:12px 12px 12px 14px;transition:box-shadow .18s,transform .18s;animation:.18s rowIn;display:flex;position:relative;overflow:hidden}.entry-row:hover{transform:translateY(-1px);box-shadow:0 3px 14px #1a171414}@keyframes rowIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.entry-accent{width:3px;position:absolute;top:0;bottom:0;left:0}.entry-info{flex:1;min-width:0}.entry-top{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.entry-name{color:#1a1714;white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:600;overflow:hidden}.entry-amount{white-space:nowrap;flex-shrink:0;font-family:Outfit,sans-serif;font-size:14px;font-weight:700}.entry-meta{flex-wrap:wrap;align-items:center;gap:6px;margin-top:6px;display:flex}.entry-badge{border-radius:20px;padding:3px 9px;font-size:10.5px;font-weight:700}.entry-date{color:#a8a29e;background:#f0ece6;border-radius:20px;padding:3px 8px;font-size:11px}.entry-note-inline{color:#a8a29e;font-size:11.5px}.entry-del{cursor:pointer;color:#c4bfb9;background:0 0;border:none;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;padding:5px;transition:background .18s,color .18s;display:flex}.entry-del:hover{color:#dc2626;background:#fee2e2}.entry-total-row{border-top:1.5px dashed #ede9e3;justify-content:space-between;align-items:center;margin-top:14px;padding:14px 0 0;display:flex}.entry-total-row span:first-child{text-transform:uppercase;letter-spacing:.6px;color:#a8a29e;font-size:11.5px;font-weight:600}.entry-total-val{font-family:Outfit,sans-serif;font-size:18px;font-weight:800}.empty-state{text-align:center;padding:36px 20px}.empty-icon{color:#c4bfb9;background:#f5f2ed;border-radius:50%;justify-content:center;align-items:center;width:58px;height:58px;margin:0 auto 14px;display:flex}.empty-title{color:#6b6560;margin-bottom:4px;font-family:Outfit,sans-serif;font-size:15px;font-weight:600}.empty-sub{color:#a8a29e;font-size:12.5px}.summary-progress-head{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.summary-progress-label{color:#3d3830;align-items:center;font-size:12.5px;font-weight:600;display:flex}.summary-progress-pct{color:#e8900a;font-family:Outfit,sans-serif;font-size:16px;font-weight:800}.summary-progress-track{background:#f5f2ed;border:1px solid #ede9e3;border-radius:10px;height:10px;overflow:hidden}.summary-progress-fill{background:linear-gradient(90deg,#e8900a,#f5c26b);border-radius:10px;height:100%;transition:width .5s}.summary-progress-row{color:#a8a29e;justify-content:space-between;margin-top:8px;font-size:11.5px;display:flex}.summary-tiles{grid-template-columns:repeat(2,1fr);gap:11px;margin-bottom:14px;display:grid}.summary-tile{background:#fff;border:1px solid #ede9e3;border-top-width:3px;border-radius:14px;flex-direction:column;gap:5px;padding:16px 15px;transition:transform .18s,box-shadow .18s;display:flex;box-shadow:0 1px 5px #1a17140d}.summary-tile:hover{transform:translateY(-2px);box-shadow:0 6px 20px #1a171417}.summary-tile-label{text-transform:uppercase;letter-spacing:.7px;color:#a8a29e;font-size:10.5px;font-weight:700}.summary-tile-val{letter-spacing:-.5px;font-family:Outfit,sans-serif;font-size:21px;font-weight:800;line-height:1.1}.summary-tile-sub{color:#c4bfb9;font-size:10.5px}.breakdown-row{border-bottom:1px solid #f5f2ed;padding:12px 0}.breakdown-row:last-of-type{border-bottom:none}.breakdown-top{justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px;display:flex}.breakdown-key{color:#3d3830;align-items:center;gap:7px;font-size:13px;font-weight:500;display:flex}.breakdown-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.breakdown-count{color:#a8a29e;background:#f5f2ed;border-radius:20px;padding:2px 7px;font-size:10.5px;font-weight:500}.breakdown-val{color:#1a1714;font-family:Outfit,sans-serif;font-size:14px;font-weight:700}.breakdown-bar-track{background:#f5f2ed;border-radius:10px;height:5px;overflow:hidden}.breakdown-bar-fill{border-radius:10px;height:100%;transition:width .5s}.breakdown-total{border-top:1.5px dashed #ede9e3;justify-content:space-between;align-items:center;margin-top:6px;padding-top:14px;display:flex}.breakdown-total span:first-child{text-transform:uppercase;letter-spacing:.6px;color:#a8a29e;font-size:11.5px;font-weight:600}@media (width<=600px){.proj-grid{grid-template-columns:1fr;padding:8px 16px 0}.tab-anim,.detail-container{flex-direction:column}.dash-header{padding:18px 16px 0}.dash-search-wrap{padding:16px 16px 10px}.dash-header-content{margin-bottom:16px}.form-grid{grid-template-columns:1fr}.form-field.form-field-full{grid-column:1}.summary-tiles{grid-template-columns:1fr 1fr}.detail-header-top{padding:13px 16px 10px}.detail-header-main{padding:0 16px 12px}.detail-header-main .detail-title{font-size:17px}.detail-content{padding:16px 14px 60px}.detail-strip-cell{min-width:80px;padding:11px 12px}.detail-strip-val{font-size:13px}.summary-tile-val{font-size:17px}.btn-new-project span{display:none}.btn-new-project{padding:11px}.modal-box{max-height:95vh}.modal-header{padding:18px 18px 14px}.modal-body{padding:16px 18px}.modal-footer{padding:14px 18px 18px}}@media (width>=601px) and (width<=900px){.proj-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=901px){.proj-grid{grid-template-columns:repeat(3,1fr)}.detail-content{padding:24px 22px 60px}}.adb-wrap *,.adb-wrap :before,.adb-wrap :after{box-sizing:border-box;margin:0;padding:0}.adb-wrap{color:#1a1714;background:#f5f2ed;min-height:100vh;font-family:DM Sans,sans-serif}.adb-header{z-index:50;background:#fff;border-bottom:1px solid #ede9e3;padding:22px 24px 0;position:sticky;top:0;box-shadow:0 1px 10px #1a171412}.adb-header-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;margin-bottom:30px;display:flex}.adb-logo{align-items:center;gap:12px;display:flex}.adb-logo-icon{color:#fff;background:linear-gradient(135deg,#e8900a,#c96d00);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-family:Outfit,sans-serif;font-size:20px;font-weight:800;display:flex;box-shadow:0 4px 14px #e8900a59}.adb-logo-title{color:#1a1714;letter-spacing:-.5px;font-family:Outfit,sans-serif;font-size:22px;font-weight:800;line-height:1.1}.adb-logo-sub{color:#a8a29e;margin-top:2px;font-size:11.5px}.adb-btn-new{color:#fff;cursor:pointer;white-space:nowrap;background:#e8900a;border:none;border-radius:10px;flex-shrink:0;align-items:center;gap:7px;padding:11px 20px;font-family:DM Sans,sans-serif;font-size:13.5px;font-weight:600;transition:background .18s,transform .18s,box-shadow .18s;display:flex;box-shadow:0 3px 12px #e8900a59}.adb-btn-new:hover{background:#cf7e08;transform:translateY(-1px);box-shadow:0 5px 18px #e8900a73}.adb-stat-strip{scrollbar-width:none;border-top:1px solid #f0ece6;margin:0 -24px;padding:0 24px;display:flex;overflow-x:auto}.adb-stat-strip::-webkit-scrollbar{display:none}.adb-stat{border-right:1px solid #f0ece6;flex-shrink:0;align-items:center;gap:10px;min-width:100px;margin-right:20px;padding:13px 20px 13px 0;display:flex}.adb-stat:last-child{border-right:none}.adb-stat-icon{border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.adb-stat-val{color:#1a1714;font-family:Outfit,sans-serif;font-size:20px;font-weight:800;line-height:1}.adb-stat-label{color:#a8a29e;white-space:nowrap;margin-top:2px;font-size:10px;font-weight:500}.adb-body{max-width:1280px;margin:0 auto;padding:22px 24px 60px}.adb-sum-grid{grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:22px;display:grid}.adb-sum-tile{background:#fff;border:1px solid #ede9e3;border-top-width:3px;border-radius:14px;padding:14px 14px 15px;transition:transform .18s,box-shadow .18s;box-shadow:0 1px 5px #1a17140a}.adb-sum-tile:hover{transform:translateY(-2px);box-shadow:0 6px 20px #1a171417}.adb-sum-tile-head{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.adb-sum-tile-label{text-transform:uppercase;letter-spacing:.7px;color:#a8a29e;font-size:9.5px;font-weight:700}.adb-sum-tile-icon{border-radius:6px;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.adb-sum-tile-val{letter-spacing:-.4px;white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-family:Outfit,sans-serif;font-size:18px;font-weight:800;line-height:1.1;overflow:hidden}.adb-sum-tile-sub{color:#c4bfb9;font-size:10px}.adb-charts-row{grid-template-columns:1.4fr 1fr 1fr;gap:14px;margin-bottom:24px;display:grid;overflow:auto}.adb-chart-card{background:#fff;border:1px solid #ede9e3;border-radius:16px;padding:18px 18px 16px;box-shadow:0 2px 8px #1a17140d}.adb-chart-card-head{justify-content:space-between;align-items:flex-start;margin-bottom:4px;display:flex}.adb-chart-card-title{text-transform:uppercase;letter-spacing:.9px;color:#a8a29e;align-items:center;gap:7px;margin-bottom:3px;font-family:Outfit,sans-serif;font-size:11px;font-weight:700;display:flex}.adb-chart-card-sub{color:#1a1714;font-size:12.5px;font-weight:600}.adb-chart-legend{flex-wrap:wrap;gap:12px;margin:10px 0 12px;display:flex}.adb-chart-legend span{color:#6b6560;align-items:center;gap:5px;font-size:11px;display:flex}.adb-leg-dot{border-radius:2px;flex-shrink:0;width:9px;height:9px}.adb-chart-canvas-wrap{width:100%;height:210px;position:relative}.adb-section-head{flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:14px;display:flex}.adb-section-title{text-transform:uppercase;letter-spacing:1px;color:#a8a29e;white-space:nowrap;align-items:center;gap:7px;font-family:Outfit,sans-serif;font-size:11px;font-weight:700;display:flex}.adb-search-box{background:#fff;border:1.5px solid #ede9e3;border-radius:10px;flex:1;align-items:center;gap:9px;min-width:180px;padding:9px 13px;transition:border-color .18s,box-shadow .18s;display:flex}.adb-search-box:focus-within{border-color:#e8900a;box-shadow:0 0 0 3px #e8900a1a}.adb-search-icon{color:#a8a29e;flex-shrink:0}.adb-search-input{color:#1a1714;background:0 0;border:none;outline:none;flex:1;font-family:DM Sans,sans-serif;font-size:13px}.adb-search-input::placeholder{color:#c4bfb9}.adb-count{color:#a8a29e;white-space:nowrap;font-size:11.5px;font-weight:500}.adb-proj-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;display:grid}.adb-pcard{background:#fff;border:1px solid #ede9e3;border-radius:16px;flex-direction:column;gap:0;padding:18px;transition:transform .2s,box-shadow .2s;animation:.22s adbCardIn;display:flex;box-shadow:0 2px 10px #1a17140d}.adb-pcard:hover{transform:translateY(-3px);box-shadow:0 8px 28px #1a17141a}@keyframes adbCardIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.adb-pcard-top{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.adb-pcard-icon{color:#e8900a;background:#fff7ed;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.adb-badge{letter-spacing:.3px;border-radius:20px;padding:3px 10px;font-size:10px;font-weight:700}.adb-badge-active{color:#16a34a;background:#dcfce7}.adb-badge-pending{color:#d97706;background:#fef3c7}.adb-badge-completed{color:#2563eb;background:#dbeafe}.adb-badge-onhold{color:#9ca3af;background:#f3f4f6}.adb-pcard-name{color:#1a1714;letter-spacing:-.2px;white-space:nowrap;text-overflow:ellipsis;margin-bottom:8px;font-family:Outfit,sans-serif;font-size:15px;font-weight:700;overflow:hidden}.adb-pcard-meta{flex-direction:column;gap:4px;margin-bottom:13px;display:flex}.adb-pcard-meta span{color:#a8a29e;align-items:center;gap:6px;font-size:11.5px;display:flex}.adb-pcard-vals{justify-content:space-between;align-items:flex-end;margin-bottom:9px;display:flex}.adb-val-label{text-transform:uppercase;letter-spacing:.5px;color:#c4bfb9;margin-bottom:2px;font-size:9.5px;font-weight:700}.adb-val-amt{color:#e8900a;font-family:Outfit,sans-serif;font-size:17px;font-weight:800}.adb-val-recv{color:#16a34a;font-family:Outfit,sans-serif;font-size:15px;font-weight:700}.adb-bar-wrap{align-items:center;gap:7px;margin-bottom:12px;display:flex}.adb-bar-track{background:#f5f2ed;border-radius:10px;flex:1;height:5px;overflow:hidden}.adb-bar-fill{background:linear-gradient(90deg,#e8900a,#f5c26b);border-radius:10px;height:100%;transition:width .5s}.adb-bar-pct{color:#e8900a;text-align:right;min-width:28px;font-family:Outfit,sans-serif;font-size:11px;font-weight:700}.adb-pcard-chips{gap:8px;margin-bottom:13px;display:flex}.adb-chip{border-radius:8px;flex:1;align-items:center;gap:5px;padding:7px 10px;font-family:Outfit,sans-serif;font-size:12px;font-weight:700;display:flex}.adb-chip-exp{color:#dc2626;background:#fef2f2}.adb-chip-profit{color:#16a34a;background:#f0fdf4}.adb-chip-loss{color:#dc2626;background:#fef2f2}.adb-pcard-actions{gap:8px;display:flex}.adb-btn-view{color:#fff;cursor:pointer;background:#e8900a;border:none;border-radius:9px;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;transition:background .18s,transform .18s;display:flex}.adb-btn-view:hover{background:#cf7e08;transform:translateY(-1px)}.adb-btn-del{color:#dc2626;cursor:pointer;background:#fef2f2;border:1px solid #fecaca;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:37px;height:37px;transition:background .18s;display:flex}.adb-btn-del:hover{background:#fee2e2}.adb-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:70px 20px;display:flex}.adb-empty-icon{color:#e8900a;background:#fff7ed;border-radius:50%;justify-content:center;align-items:center;width:70px;height:70px;margin-bottom:16px;display:flex}.adb-empty-title{color:#1a1714;margin-bottom:6px;font-family:Outfit,sans-serif;font-size:19px;font-weight:700}@media (width<=1100px){.adb-sum-grid{grid-template-columns:repeat(3,1fr)}.adb-charts-row{grid-template-columns:1fr 1fr}.adb-charts-row .adb-chart-card:last-child{grid-column:1/-1}}@media (width<=640px){.adb-header{padding:16px 16px 0}.adb-body{padding:16px 14px 50px}.adb-sum-grid{grid-template-columns:1fr 1fr}.adb-sum-tile-val{font-size:15px}.adb-charts-row,.adb-proj-grid{grid-template-columns:1fr}.adb-section-head{flex-wrap:wrap}.adb-btn-new span{display:none}.adb-btn-new{padding:11px 13px}.adb-header-inner{margin-bottom:16px}}@media (width>=641px) and (width<=1100px){.adb-body{padding:18px 20px 50px}.adb-proj-grid{grid-template-columns:repeat(2,1fr)}}.rpt-wrap *,.rpt-wrap :before,.rpt-wrap :after{box-sizing:border-box;margin:0;padding:0}.rpt-wrap{color:#1a1714;background:#f5f2ed;min-height:100vh;font-family:DM Sans,sans-serif}.rpt-header{z-index:50;background:#fff;border-bottom:1px solid #ede9e3;padding:20px 24px 0;position:sticky;top:0;box-shadow:0 1px 10px #1a171412}.rpt-header-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;display:flex}.rpt-header-left{align-items:center;gap:13px;display:flex}.rpt-header-icon{color:#fff;background:linear-gradient(135deg,#e8900a,#c96d00);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex;box-shadow:0 4px 14px #e8900a59}.rpt-title{color:#1a1714;letter-spacing:-.5px;font-family:Outfit,sans-serif;font-size:22px;font-weight:800;line-height:1.1}.rpt-subtitle{color:#a8a29e;margin-top:2px;font-size:11.5px}.rpt-tabbar{scrollbar-width:none;border-top:1px solid #f0ece6;gap:2px;margin:0 -24px;padding:0 24px;display:flex;overflow-x:auto}.rpt-tabbar::-webkit-scrollbar{display:none}.rpt-tab{color:#a8a29e;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2.5px solid #0000;flex-shrink:0;align-items:center;gap:6px;padding:11px 16px 12px;font-family:DM Sans,sans-serif;font-size:12.5px;font-weight:500;transition:color .18s,border-color .18s;display:flex}.rpt-tab:hover{color:#e8900a}.rpt-tab.rpt-tab-active{color:#e8900a;border-bottom-color:#e8900a;font-weight:600}.rpt-body{max-width:1280px;margin:0 auto;padding:20px 24px 60px}.rpt-tab-content{flex-direction:column;gap:16px;animation:.2s rptFadeIn;display:flex}@keyframes rptFadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.rpt-filterbar{background:#fff;border:1px solid #ede9e3;border-radius:14px;flex-wrap:wrap;align-items:flex-end;gap:14px;margin-bottom:14px;padding:16px 18px;display:flex;box-shadow:0 1px 6px #1a17140d}.rpt-filterbar-left{flex-shrink:0;align-items:center;gap:8px;display:flex}.rpt-filter-icon{color:#e8900a;background:#fff7ed;border-radius:9px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.rpt-filter-label{text-transform:uppercase;letter-spacing:.9px;color:#a8a29e;white-space:nowrap;font-family:Outfit,sans-serif;font-size:11px;font-weight:700}.rpt-filterbar-fields{flex-wrap:wrap;flex:1;gap:10px;display:flex}.rpt-field{flex-direction:column;flex:1;gap:5px;min-width:130px;display:flex}.rpt-field-label{text-transform:uppercase;letter-spacing:.8px;color:#a8a29e;font-size:10px;font-weight:700}.rpt-select-wrap{align-items:center;display:flex;position:relative}.rpt-select{color:#1a1714;appearance:none;cursor:pointer;background:#faf8f5;border:1.5px solid #ede9e3;border-radius:9px;outline:none;width:100%;padding:9px 30px 9px 11px;font-family:DM Sans,sans-serif;font-size:12.5px;transition:border-color .18s,box-shadow .18s}.rpt-select:focus{background:#fff;border-color:#e8900a;box-shadow:0 0 0 3px #e8900a1a}.rpt-select-arrow{color:#a8a29e;pointer-events:none;position:absolute;right:10px}.rpt-input-wrap{align-items:center;display:flex;position:relative}.rpt-input-icon{color:#a8a29e;pointer-events:none;z-index:1;position:absolute;left:10px}.rpt-input{color:#1a1714;background:#faf8f5;border:1.5px solid #ede9e3;border-radius:9px;outline:none;width:100%;padding:9px 11px;font-family:DM Sans,sans-serif;font-size:12.5px;transition:border-color .18s,box-shadow .18s}.rpt-input:focus{background:#fff;border-color:#e8900a;box-shadow:0 0 0 3px #e8900a1a}.rpt-input::placeholder{color:#c4bfb9}.rpt-input-icon-pad{padding-left:28px}.rpt-reset-btn{color:#6b6560;cursor:pointer;white-space:nowrap;background:#f5f2ed;border:1px solid #ede9e3;border-radius:9px;flex-shrink:0;align-items:center;gap:6px;padding:9px 16px;font-family:DM Sans,sans-serif;font-size:12.5px;font-weight:500;transition:background .18s;display:flex}.rpt-reset-btn:hover{background:#ede9e3}.rpt-active-filters{color:#e8900a;background:#fff7ed;border:1px solid #fde68a;border-radius:9px;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:6px;padding:8px 14px;font-size:12px;display:flex}.rpt-clear-btn{color:#fff;cursor:pointer;background:#e8900a;border:none;border-radius:6px;align-items:center;gap:4px;margin-left:auto;padding:4px 10px;font-size:11px;font-weight:600;display:flex}.rpt-exportbar{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.rpt-exportbar-left{color:#6b6560;align-items:center;gap:8px;display:flex}.rpt-export-label{text-transform:uppercase;letter-spacing:.8px;color:#a8a29e;white-space:nowrap;font-family:Outfit,sans-serif;font-size:11px;font-weight:700}.rpt-export-count{color:#a8a29e;background:#f5f2ed;border-radius:20px;padding:2px 8px;font-size:11px}.rpt-export-btns{flex-wrap:wrap;gap:7px;display:flex}.rpt-exp-btn{cursor:pointer;white-space:nowrap;background:#fff;border:1.5px solid #ede9e3;border-radius:9px;align-items:center;gap:6px;padding:9px 15px;font-family:DM Sans,sans-serif;font-size:12.5px;font-weight:600;transition:background .18s,border-color .18s,transform .15s;display:flex}.rpt-exp-btn:hover{transform:translateY(-1px)}.rpt-exp-csv{color:#16a34a;border-color:#86efac}.rpt-exp-csv:hover{background:#f0fdf4;border-color:#16a34a}.rpt-exp-xlsx{color:#2563eb;border-color:#93c5fd}.rpt-exp-xlsx:hover{background:#eff6ff;border-color:#2563eb}.rpt-exp-json{color:#7c3aed;border-color:#c4b5fd}.rpt-exp-json:hover{background:#f5f3ff;border-color:#7c3aed}.rpt-exp-pdf{color:#dc2626;border-color:#fca5a5}.rpt-exp-pdf:hover{background:#fef2f2;border-color:#dc2626}.rpt-kpi-grid{grid-template-columns:repeat(6,1fr);gap:12px;display:grid}.rpt-kpi{background:#fff;border:1px solid #ede9e3;border-top-width:3px;border-radius:14px;padding:14px 14px 15px;transition:transform .18s,box-shadow .18s;box-shadow:0 1px 5px #1a17140a}.rpt-kpi:hover{transform:translateY(-2px);box-shadow:0 6px 20px #1a171417}.rpt-kpi-head{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.rpt-kpi-label{text-transform:uppercase;letter-spacing:.7px;color:#a8a29e;font-size:9.5px;font-weight:700}.rpt-kpi-icon{border-radius:6px;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.rpt-kpi-val{letter-spacing:-.4px;white-space:nowrap;text-overflow:ellipsis;margin-bottom:3px;font-family:Outfit,sans-serif;font-size:17px;font-weight:800;line-height:1.15;overflow:hidden}.rpt-kpi-sub{color:#c4bfb9;margin-bottom:4px;font-size:10px}.rpt-kpi-trend{border-radius:20px;align-items:center;gap:3px;padding:2px 7px;font-size:10px;font-weight:700;display:inline-flex}.rpt-trend-up{color:#16a34a;background:#f0fdf4}.rpt-trend-down{color:#dc2626;background:#fef2f2}.rpt-card{background:#fff;border:1px solid #ede9e3;border-radius:16px;padding:18px 18px 20px;box-shadow:0 1px 6px #1a17140d}.rpt-card-head{text-transform:uppercase;letter-spacing:1px;color:#a8a29e;align-items:center;gap:8px;margin-bottom:14px;font-family:Outfit,sans-serif;font-size:11px;font-weight:700;display:flex}.rpt-charts-3col{grid-template-columns:1.4fr 1fr 1fr;gap:14px;display:grid;overflow-y:auto}.rpt-chart-legend{flex-wrap:wrap;gap:12px;margin-bottom:12px;display:flex}.rpt-chart-legend span{color:#6b6560;align-items:center;gap:5px;font-size:11px;display:flex}.rpt-leg-dot{border-radius:2px;flex-shrink:0;width:9px;height:9px}.rpt-canvas-wrap{width:100%;height:200px;position:relative}.rpt-exp-tiles{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.rpt-exp-tile{background:#fff;border:1px solid #ede9e3;border-top-width:3px;border-radius:14px;padding:15px 14px;box-shadow:0 1px 5px #1a17140a}.rpt-exp-tile-label{text-transform:uppercase;letter-spacing:.7px;color:#a8a29e;margin-bottom:6px;font-size:10px;font-weight:700}.rpt-exp-tile-val{margin-bottom:8px;font-family:Outfit,sans-serif;font-size:20px;font-weight:800}.rpt-exp-tile-bar-track{background:#f5f2ed;border-radius:10px;height:5px;margin-bottom:6px;overflow:hidden}.rpt-exp-tile-bar-fill{border-radius:10px;height:100%;transition:width .5s}.rpt-exp-tile-sub{color:#c4bfb9;font-size:10px}.rpt-table-scroll{-webkit-overflow-scrolling:touch;overflow-x:auto}.rpt-table{border-collapse:collapse;width:100%;min-width:680px;font-size:13px}.rpt-th{text-align:left;text-transform:uppercase;letter-spacing:.8px;color:#a8a29e;white-space:nowrap;background:#faf8f5;border-bottom:1.5px solid #ede9e3;padding:9px 12px;font-size:9.5px;font-weight:700}.rpt-td{vertical-align:middle;color:#1a1714;border-bottom:1px solid #f5f2ed;padding:11px 12px}.rpt-tr:last-child .rpt-td{border-bottom:none}.rpt-tr:hover .rpt-td{background:#faf8f5}.rpt-td-num{text-align:right;font-family:Outfit,sans-serif;font-size:13px;font-weight:600}.rpt-td-sm{color:#6b6560;font-size:12px}.rpt-empty-cell{text-align:center;color:#a8a29e;padding:32px;font-size:13px}.rpt-td-proj{align-items:center;gap:10px;display:flex}.rpt-td-proj-icon{color:#e8900a;background:#fff7ed;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.rpt-td-proj-name{color:#1a1714;white-space:nowrap;font-size:13px;font-weight:600}.rpt-td-proj-loc{color:#a8a29e;align-items:center;gap:3px;margin-top:2px;font-size:10.5px;display:flex}.rpt-td-client{color:#6b6560;align-items:center;gap:5px;font-size:12px;display:flex}.rpt-badge{white-space:nowrap;border-radius:20px;padding:3px 9px;font-size:10px;font-weight:700}.rpt-badge-active{color:#16a34a;background:#dcfce7}.rpt-badge-pending{color:#d97706;background:#fef3c7}.rpt-badge-completed{color:#2563eb;background:#dbeafe}.rpt-badge-onhold{color:#9ca3af;background:#f3f4f6}.rpt-td-bar-wrap{align-items:center;gap:7px;min-width:100px;display:flex}.rpt-td-bar-track{background:#f5f2ed;border-radius:10px;flex:1;height:5px;overflow:hidden}.rpt-td-bar-fill{background:linear-gradient(90deg,#e8900a,#f5c26b);border-radius:10px;height:100%;transition:width .4s}.rpt-td-bar-pct{color:#e8900a;text-align:right;min-width:30px;font-family:Outfit,sans-serif;font-size:11px;font-weight:700}.rpt-tfoot-row .rpt-td{background:#faf8f5;border-top:1.5px solid #ede9e3;border-bottom:none}.rpt-tfoot-label{text-transform:uppercase;letter-spacing:.7px;color:#a8a29e;font-family:Outfit,sans-serif;font-size:11px;font-weight:700}.rpt-tfoot-val{color:#1a1714;font-family:Outfit,sans-serif;font-size:14px;font-weight:800}@media print{.rpt-header,.rpt-exportbar,.rpt-filterbar,.rpt-tabbar,.rpt-exp-btn,.rpt-reset-btn{display:none!important}.rpt-wrap{background:#fff}.rpt-body{padding:10px}.rpt-card{box-shadow:none;page-break-inside:avoid;border:1px solid #ddd}.rpt-kpi{box-shadow:none;border:1px solid #ddd}}@media (width<=1100px){.rpt-kpi-grid{grid-template-columns:repeat(3,1fr)}.rpt-charts-3col{grid-template-columns:1fr 1fr}.rpt-charts-3col .rpt-card:last-child{grid-column:1/-1}.rpt-exp-tiles{grid-template-columns:repeat(3,1fr)}}@media (width<=820px){.rpt-header{padding:16px 18px 0}.rpt-body{padding:16px 16px 50px}.rpt-kpi-grid{grid-template-columns:repeat(2,1fr)}.rpt-charts-3col{grid-template-columns:1fr}.rpt-exp-tiles{grid-template-columns:1fr 1fr}.rpt-filterbar-fields{gap:8px}.rpt-field{min-width:110px}}@media (width<=600px){.rpt-header{padding:14px 14px 0}.rpt-body{padding:14px 12px 50px}.rpt-header-inner{gap:10px}.rpt-title{font-size:18px}.rpt-kpi-grid{grid-template-columns:1fr 1fr}.rpt-kpi-val{font-size:14px}.rpt-charts-3col,.rpt-exp-tiles{grid-template-columns:1fr}.rpt-filterbar{flex-direction:column;align-items:flex-start;gap:12px}.rpt-filterbar-fields{flex-direction:column;width:100%}.rpt-field{min-width:100%}.rpt-reset-btn{justify-content:center;width:100%}.rpt-export-btns{gap:5px}.rpt-exp-btn{padding:8px 11px;font-size:11.5px}.rpt-exportbar{gap:10px}.rpt-tab{padding:9px 12px 10px;font-size:12px}.rpt-col-exp,.rpt-col-value{display:none}}.asc-loader-root{z-index:9999;background:#0a0a0a;justify-content:center;align-items:center;transition:opacity .6s cubic-bezier(.4,0,.2,1),transform .6s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;inset:0;overflow:hidden}.asc-loader-root.asc-loader-exit{opacity:0;pointer-events:none;transform:scale(1.05)}.asc-loader-grid{background-image:linear-gradient(#ffffff08 1px,#0000 1px),linear-gradient(90deg,#ffffff08 1px,#0000 1px);background-size:60px 60px;animation:20s linear infinite asc-grid-drift;position:absolute;inset:0}@keyframes asc-grid-drift{to{background-position:60px 60px}}.asc-loader-glow{pointer-events:none;background:radial-gradient(#b4966414 0%,#0000 70%);width:120%;height:70%;position:absolute;top:-40%;left:50%;transform:translate(-50%)}.asc-loader-line{background:linear-gradient(#0000,#b496644d,#0000);width:1px;height:0;animation:2s cubic-bezier(.22,1,.36,1) forwards asc-line-grow;position:absolute}.asc-loader-line--left{animation-delay:.2s;top:10%;left:18%}.asc-loader-line--left-2{animation-delay:.5s;top:20%;left:22%}.asc-loader-line--right{animation-delay:.35s;top:10%;right:18%}.asc-loader-line--right-2{animation-delay:.6s;top:20%;right:22%}@keyframes asc-line-grow{to{height:80vh}}.asc-loader-corner{opacity:0;border:0 solid #b4966440;width:40px;height:40px;animation:.8s cubic-bezier(.22,1,.36,1) .4s forwards asc-corner-in;position:absolute}.asc-loader-corner--tl{border-top-width:1px;border-left-width:1px;top:32px;left:32px}.asc-loader-corner--tr{border-top-width:1px;border-right-width:1px;top:32px;right:32px}.asc-loader-corner--bl{border-bottom-width:1px;border-left-width:1px;bottom:32px;left:32px}.asc-loader-corner--br{border-bottom-width:1px;border-right-width:1px;bottom:32px;right:32px}@keyframes asc-corner-in{to{opacity:1}}.asc-loader-center{z-index:2;flex-direction:column;align-items:center;gap:20px;display:flex;position:relative}.asc-loader-logo-wrap{justify-content:center;align-items:center;width:140px;height:140px;display:flex;position:relative}.asc-loader-logo-ring{border:1px solid #0000;border-radius:50%;position:absolute}.asc-loader-logo-ring--outer{border-top-color:#b4966499;border-right-color:#b4966426;animation:2.4s linear infinite asc-ring-spin;inset:-10px}.asc-loader-logo-ring--inner{border-bottom-color:#b4966459;border-left-color:#b496641a;animation:1.8s linear infinite asc-ring-spin-reverse;inset:0}@keyframes asc-ring-spin{to{transform:rotate(360deg)}}@keyframes asc-ring-spin-reverse{to{transform:rotate(-360deg)}}.asc-loader-logo-mask{background:#0f0f0f;border-radius:50%;justify-content:center;align-items:center;width:110px;height:110px;animation:3s ease-in-out infinite asc-logo-breathe;display:flex;overflow:hidden}.asc-loader-logo-img{object-fit:contain;filter:brightness(0)invert()drop-shadow(0 0 6px #b496644d);width:80%;height:80%;animation:1.2s cubic-bezier(.22,1,.36,1) .3s both asc-logo-reveal}@keyframes asc-logo-reveal{0%{opacity:0;filter:brightness(0)invert()drop-shadow(0 0 6px #b496644d)blur(8px);transform:scale(.6)rotateY(90deg)}to{opacity:1;filter:brightness(0)invert()drop-shadow(0 0 6px #b496644d)blur();transform:scale(1)rotateY(0)}}@keyframes asc-logo-breathe{0%,to{box-shadow:0 0 #b4966426}50%{box-shadow:0 0 30px 4px #b4966414}}.asc-loader-pulse{background:#b49664b3;border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite asc-pulse-beat;position:absolute}.asc-loader-pulse--n{animation-delay:0s;top:-14px;left:50%;transform:translate(-50%)}.asc-loader-pulse--e{animation-delay:.5s;top:50%;right:-14px;transform:translateY(-50%)}.asc-loader-pulse--s{animation-delay:1s;bottom:-14px;left:50%;transform:translate(-50%)}.asc-loader-pulse--w{animation-delay:1.5s;top:50%;left:-14px;transform:translateY(-50%)}@keyframes asc-pulse-beat{0%,to{opacity:.4;transform:scale(1);box-shadow:0 0 #b4966466}50%{opacity:1;transform:scale(1.8);box-shadow:0 0 10px 3px #b4966426}}.asc-loader-pulse--n{animation-name:asc-pulse-n}.asc-loader-pulse--e{animation-name:asc-pulse-e}.asc-loader-pulse--s{animation-name:asc-pulse-s}.asc-loader-pulse--w{animation-name:asc-pulse-w}@keyframes asc-pulse-n{0%,to{opacity:.4;transform:translate(-50%)scale(1);box-shadow:0 0 #b4966466}50%{opacity:1;transform:translate(-50%)scale(1.8);box-shadow:0 0 10px 3px #b4966426}}@keyframes asc-pulse-e{0%,to{opacity:.4;transform:translateY(-50%)scale(1);box-shadow:0 0 #b4966466}50%{opacity:1;transform:translateY(-50%)scale(1.8);box-shadow:0 0 10px 3px #b4966426}}@keyframes asc-pulse-s{0%,to{opacity:.4;transform:translate(-50%)scale(1);box-shadow:0 0 #b4966466}50%{opacity:1;transform:translate(-50%)scale(1.8);box-shadow:0 0 10px 3px #b4966426}}@keyframes asc-pulse-w{0%,to{opacity:.4;transform:translateY(-50%)scale(1);box-shadow:0 0 #b4966466}50%{opacity:1;transform:translateY(-50%)scale(1.8);box-shadow:0 0 10px 3px #b4966426}}.asc-loader-brand{letter-spacing:6px;color:#ffffffb3;margin:0;font-family:Inter,Helvetica Neue,sans-serif;font-size:13px;font-weight:600;animation:1s cubic-bezier(.22,1,.36,1) .6s both asc-text-in}@keyframes asc-text-in{0%{opacity:0;letter-spacing:12px;transform:translateY(12px)}to{opacity:1;letter-spacing:6px;transform:translateY(0)}}.asc-loader-divider{align-items:center;gap:10px;animation:.8s cubic-bezier(.22,1,.36,1) .8s both asc-text-in;display:flex}.asc-loader-divider-line{background:linear-gradient(90deg,#0000,#b4966466,#0000);width:40px;height:1px;display:block}.asc-loader-divider-dot{background:#b4966480;border-radius:50%;width:4px;height:4px;animation:2s ease-in-out infinite asc-dot-blink;display:block}@keyframes asc-dot-blink{0%,to{opacity:.3}50%{opacity:1}}.asc-loader-bar-track{background:#ffffff0f;border-radius:2px;width:200px;height:2px;animation:.8s cubic-bezier(.22,1,.36,1) 1s both asc-text-in;position:relative;overflow:visible}.asc-loader-bar-fill{background:linear-gradient(90deg,#b496644d,#b49664e6);border-radius:2px;height:100%;transition:width 50ms linear;box-shadow:0 0 12px #b496644d}.asc-loader-bar-glow{pointer-events:none;background:radial-gradient(circle,#b4966466,#0000 70%);border-radius:50%;width:20px;height:20px;transition:left 50ms linear;position:absolute;top:50%;transform:translate(-50%,-50%)}.asc-loader-pct{letter-spacing:3px;color:#b4966499;font-family:Inter,monospace;font-size:11px;font-weight:500;animation:.8s cubic-bezier(.22,1,.36,1) 1.1s both asc-text-in}.asc-loader-tagline{letter-spacing:3px;color:#fff3;white-space:nowrap;margin:0;font-family:Inter,Georgia,serif;font-size:11px;font-weight:300;animation:1.2s cubic-bezier(.22,1,.36,1) 1.4s both asc-tagline-in;position:absolute;bottom:40px;left:50%;transform:translate(-50%)}@keyframes asc-tagline-in{0%{opacity:0;transform:translate(-50%)translateY(10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@media (width<=480px){.asc-loader-logo-wrap{width:110px;height:110px}.asc-loader-logo-mask{width:86px;height:86px}.asc-loader-bar-track{width:160px}.asc-loader-brand{letter-spacing:4px;font-size:11px}.asc-loader-line--left-2,.asc-loader-line--right-2{display:none}}@media (prefers-reduced-motion:reduce){.asc-loader-grid,.asc-loader-logo-ring--outer,.asc-loader-logo-ring--inner,.asc-loader-pulse,.asc-loader-divider-dot,.asc-loader-logo-mask{animation:none}.asc-loader-line{height:80vh;animation:none}.asc-loader-corner{opacity:1;animation:none}}.counter{color:var(--accent);background:var(--accent-bg);border:2px solid #0000;border-radius:5px;margin-bottom:24px;padding:5px 10px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}
