@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root,body.theme-midnight{--bg-color:#0b1120;--glass-bg:#1e293bb3;--glass-border:#ffffff1a;--glass-shadow:0 8px 32px 0 #0000005e;--accent-teal:#0ea5e9;--accent-green:#10b981;--accent-amber:#f59e0b;--accent-pink:#d946ef;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--font-family:"Inter", sans-serif}body.theme-light{--bg-color:#f1f5f9;--glass-bg:#ffffffb3;--glass-border:#fff6;--glass-shadow:0 8px 32px 0 #0000001a;--accent-teal:#0284c7;--accent-green:#059669;--accent-amber:#d97706;--accent-pink:#c026d3;--text-primary:#0f172a;--text-secondary:#334155;--text-muted:#64748b}body.theme-dark-high-contrast{--bg-color:#000;--glass-bg:#000000e6;--glass-border:#ffffff4d;--glass-shadow:0 8px 32px 0 #ffffff1a;--accent-teal:#38bdf8;--accent-green:#34d399;--accent-amber:#fbbf24;--accent-pink:#f472b6;--text-primary:#fff;--text-secondary:#cbd5e1;--text-muted:#94a3b8}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--bg-color);color:var(--text-primary);background-image:radial-gradient(circle at 15%,#0ea5e926,#0000 25%),radial-gradient(circle at 85% 30%,#d946ef26,#0000 25%);background-attachment:fixed;min-height:100vh;transition:background-color .3s,color .3s;overflow-x:hidden}body.theme-light{background-image:radial-gradient(circle at 15%,#0ea5e90d,#0000 25%),radial-gradient(circle at 85% 30%,#d946ef0d,#0000 25%)}body.theme-dark-high-contrast{background-image:none}.glass-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:16px}.glass-button{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:var(--accent-teal);font-family:var(--font-family);cursor:pointer;background:#0ea5e933;border:1px solid #0ea5e980;border-radius:8px;padding:8px 16px;font-weight:500;transition:all .2s ease-in-out}.glass-button:hover{background:#0ea5e94d;box-shadow:0 0 15px #0ea5e966}.glass-button.primary{background:var(--accent-teal);color:#fff;border:none}.glass-button.primary:hover{background:#0284c7;box-shadow:0 0 20px #0ea5e999}h1,h2,h3,h4,h5,h6{color:var(--text-primary);margin-bottom:.5em;font-weight:600}p{color:var(--text-secondary);line-height:1.6}.badge{text-transform:uppercase;letter-spacing:.05em;border-radius:9999px;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-block}.badge.completed{color:var(--accent-green);background:#10b98126;border:1px solid #10b9814d}.badge.in-progress{color:var(--accent-teal);background:#0ea5e926;border:1px solid #0ea5e94d}.badge.warning{color:var(--accent-amber);background:#f59e0b26;border:1px solid #f59e0b4d}.glass-input{border:1px solid var(--glass-border);width:100%;color:var(--text-primary);font-family:var(--font-family);background:#0003;border-radius:8px;outline:none;padding:10px 14px;transition:border-color .2s}.glass-input:focus{border-color:var(--accent-teal);box-shadow:0 0 0 2px #0ea5e933}.glass-label{color:var(--text-secondary);margin-bottom:6px;font-size:.875rem;display:block}.app-container{height:100vh;display:flex;position:relative;overflow:hidden}.main-content{flex:1;padding:2rem;overflow-y:auto}.mobile-header{display:none}.sidebar-wrapper{height:100%}.sidebar-overlay{display:none}@media (width<=768px){.app-container{flex-direction:column}.mobile-header{background:var(--glass-bg);border-bottom:1px solid var(--glass-border);z-index:100;align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.mobile-menu-btn{color:var(--text-primary);cursor:pointer;background:0 0;border:none;align-items:center;padding:4px;display:flex}.mobile-title{color:var(--accent-teal);font-size:1.1rem;font-weight:600}.sidebar-wrapper{z-index:200;width:280px;height:100%;transition:left .3s;position:fixed;top:0;left:-280px}.sidebar-wrapper.open{left:0}.sidebar-wrapper .sidebar{width:100%;height:100%}.sidebar-overlay{z-index:150;background:#0009;display:block;position:fixed;inset:0}.main-content{height:calc(100vh - 52px);padding:1.25rem}.glass-table{display:block;overflow-x:auto}.grid-2-col,.grid-4-col,.grid-charts{grid-template-columns:1fr!important}.page-header{flex-direction:column;gap:1rem}.action-buttons{flex-wrap:wrap}.tab-bar{-webkit-overflow-scrolling:touch;padding-bottom:4px;overflow-x:auto}}.glass-table{border-collapse:separate;border-spacing:0;text-align:left;width:100%}.glass-table th{color:var(--text-muted);border-bottom:1px solid var(--glass-border);padding:1rem;font-size:.875rem;font-weight:500}.glass-table td{border-bottom:1px solid var(--glass-border);color:var(--text-secondary);padding:1rem;transition:background-color .2s}body.density-compact .glass-table th,body.density-compact .glass-table td{padding:.5rem 1rem}body.density-compact .glass-panel{padding:1rem!important}.glass-table tr:hover td{cursor:pointer;background-color:#ffffff08}.tooltip-container{display:inline-block;position:relative}.tooltip-container .tooltip-text{visibility:hidden;width:max-content;max-width:250px;color:var(--text-primary);text-align:left;z-index:50;opacity:0;border:1px solid var(--glass-border);background-color:#0f172af2;border-radius:6px;padding:8px 12px;font-size:.8rem;font-weight:400;transition:opacity .2s,bottom .2s;position:absolute;bottom:125%;left:50%;transform:translate(-50%);box-shadow:0 4px 15px #00000080}.tooltip-container .tooltip-text:after{content:"";border:5px solid #0000;border-top-color:#0f172af2;margin-left:-5px;position:absolute;top:100%;left:50%}.tooltip-container:hover .tooltip-text{visibility:visible;opacity:1;bottom:110%}.expanded-card-active{grid-column:1/-1;transition:all .4s cubic-bezier(.175,.885,.32,1.275)}@keyframes flyUp{0%{opacity:0;transform:translateY(0)scale(.5)rotate(0)}10%{opacity:1;transform:translateY(-10vh)scale(1)rotate(10deg)}90%{opacity:1}to{opacity:0;transform:translateY(-110vh)scale(1.5)rotate(-20deg)}}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-content{flex-direction:column;width:90%;max-width:600px;max-height:90vh;animation:.3s ease-out slideUp;display:flex}.modal-header{border-bottom:1px solid var(--glass-border);justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-header h3{color:var(--accent-teal);margin:0}.close-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;transition:all .2s;display:flex}.close-btn:hover{color:var(--text-primary);background:#ffffff1a}.modal-body{padding:1.5rem;overflow-y:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.sidebar{border-top:none;border-bottom:none;border-left:none;border-radius:0;flex-direction:column;width:250px;height:100%;padding:1.25rem 0;display:flex;overflow-y:auto}.sidebar-header{padding:0 1.25rem 1rem}.sidebar-section{margin-bottom:.5rem}.section-label{color:var(--text-muted);letter-spacing:1.5px;text-transform:uppercase;padding:.75rem 1.25rem .4rem;font-size:.65rem;font-weight:600;display:block}.sidebar-nav{flex-direction:column;gap:2px;padding:0 .75rem;display:flex}.nav-item{color:var(--text-secondary);border-radius:8px;align-items:center;gap:.75rem;padding:.6rem .75rem;font-size:.9rem;text-decoration:none;transition:all .2s;display:flex}.nav-item:hover{color:var(--text-primary);background:#ffffff0d}.nav-item.active{color:var(--accent-teal);border-left:3px solid var(--accent-teal);background:#0ea5e91f}.project-selector-wrapper{margin-bottom:1.5rem;padding:0 1rem;position:relative}.project-selector{border:1px solid var(--glass-border);width:100%;color:var(--text-primary);font-family:var(--font-family);cursor:pointer;background:#ffffff0d;border-radius:8px;justify-content:space-between;align-items:center;padding:.6rem .75rem;font-size:.85rem;transition:all .2s;display:flex}.project-selector:hover{background:#ffffff14;border-color:#fff3}.project-dropdown{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);z-index:50;border-radius:10px;max-height:320px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:hidden auto;box-shadow:0 12px 40px #00000080}.project-dropdown-item{width:100%;color:var(--text-secondary);font-family:var(--font-family);cursor:pointer;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;gap:.5rem;padding:.55rem .75rem;font-size:.85rem;transition:all .15s;display:flex}.project-dropdown-item:hover{color:var(--text-primary);background:#ffffff0f}.project-dropdown-item.active{color:var(--accent-teal);background:#0ea5e914}.project-dropdown-item.new-project{color:var(--accent-teal);justify-content:flex-start;gap:.4rem}.phase-nav-item{align-items:center;gap:0;display:flex}.phase-nav-item .nav-item{flex:1;min-width:0}.phase-remove-btn{color:var(--text-muted);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;transition:all .15s;display:flex}.phase-nav-item:hover .phase-remove-btn{opacity:1}.phase-remove-btn:hover{color:var(--accent-pink);background:#d946ef1a}.add-phase-btn{opacity:.7;cursor:pointer;font-family:var(--font-family);background:0 0;border:none;font-size:.9rem;color:var(--accent-teal)!important}.add-phase-btn:hover{opacity:1}.quick-expense-btn{border:1px dashed var(--accent-teal);width:100%;color:var(--accent-teal);font-family:var(--font-family);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;padding:.6rem;font-size:.85rem;font-weight:500;transition:all .2s;display:flex}.quick-expense-btn:hover{background:#0ea5e91a;border-style:solid}.sidebar-footer{flex-direction:column;gap:.75rem;margin-top:auto;padding:1rem;display:flex}
