@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5476f68d60460930-s.0wxq9webf.ew4.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_5972bc34-module__OU16Qa__className{font-family:Inter,Inter Fallback;font-style:normal}
:root{--color-bg-primary:#f9fafb;--color-bg-secondary:#f3f4f6;--color-bg-tertiary:#e5e7eb;--color-bg-elevated:#fff;--color-surface:#fff;--color-surface-hover:#f3f4f6;--color-accent-primary:#1e3a8a;--color-accent-secondary:#3b82f6;--color-accent-glow:#1e3a8a1a;--color-text-primary:#111827;--color-text-secondary:#6b7280;--color-text-tertiary:#9ca3af;--color-border:#00000014;--color-border-hover:#00000026;--color-success:#16a34a;--color-warning:#f59e0b;--color-error:#dc2626;--color-info:#3b82f6;--color-highlight:#fbbf24;--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:2rem;--font-weight-light:300;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--spacing-xs:.25rem;--spacing-sm:.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #00000014, 0 2px 4px -1px #0000000a;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -2px #0000000a;--shadow-xl:0 20px 25px -5px #0000001a, 0 10px 10px -5px #0000000a;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.35s cubic-bezier(.4, 0, .2, 1);--sidebar-width:260px;--topbar-height:72px}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-normal);color:var(--color-text-primary);background:var(--color-bg-primary);line-height:1.6;overflow-x:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-bg-elevated);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--color-surface-hover)}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);line-height:1.2}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}a{color:var(--color-accent-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-accent-secondary)}.logo-text{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);background:linear-gradient(135deg, var(--color-accent-primary), var(--color-accent-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.typing-indicator{align-items:center;gap:4px;height:24px;padding:0 4px;display:flex}.typing-dot{background-color:var(--color-text-secondary);border-radius:50%;width:6px;height:6px;animation:1.4s ease-in-out infinite both typingBounce}.typing-dot:first-child{animation-delay:-.32s}.typing-dot:nth-child(2){animation-delay:-.16s}@keyframes typingBounce{0%,80%,to{opacity:.5;transform:scale(0)}40%{opacity:1;transform:scale(1)}}.btn{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-xl);font-size:var(--font-size-base);font-weight:var(--font-weight-bold);border-radius:var(--radius-md);transition:all var(--transition-base);display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--color-accent-primary), var(--color-accent-secondary));color:#fff;box-shadow:var(--shadow-md)}.btn-primary:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}.btn-secondary{background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-surface-hover);border-color:var(--color-border-hover)}.btn-icon{border-radius:var(--radius-md);width:40px;height:40px;color:var(--color-text-primary);transition:all var(--transition-base);background:0 0;justify-content:center;align-items:center;display:flex}.btn-icon:hover{background:var(--color-surface);color:var(--color-text-primary)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--transition-base)}.card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-md)}.badge{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.05em;align-items:center;display:inline-flex}.badge-success{color:var(--color-success);background:#16a34a1a}.badge-warning{color:var(--color-warning);background:#f59e0b1a}.badge-error{color:var(--color-error);background:#dc26261a}.badge-info{color:var(--color-info);background:#3b82f61a}.badge-neutral{background:var(--color-bg-elevated);color:var(--color-text-secondary)}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.text-accent{color:var(--color-accent-primary)}.text-success{color:var(--color-success)}.text-error{color:var(--color-error)}.text-warning{color:var(--color-warning)}.bg-surface{background:var(--color-surface)}.bg-elevated{background:var(--color-bg-elevated)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.animate-fade-in{animation:fadeIn var(--transition-base) ease-out}.animate-slide-in{animation:slideIn var(--transition-base) ease-out}.form-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast);outline:none}.form-input:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 2px var(--color-accent-glow)}.form-input::placeholder{color:var(--color-text-tertiary)}select.form-input{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M3 5L6 8L9 5' stroke='%236e6e7a' stroke-width='1.5' stroke-linecap='round' fill='none'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:28px}textarea.form-input{resize:vertical;min-height:80px}.form-group{gap:var(--spacing-xs);flex-direction:column;display:flex}.form-group label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.notification{bottom:var(--spacing-xl);right:var(--spacing-xl);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);box-shadow:var(--shadow-xl);opacity:0;z-index:9999;pointer-events:none;align-items:center;gap:var(--spacing-sm);border-left:4px solid var(--color-info);transition:all .3s cubic-bezier(.68,-.55,.265,1.55);display:flex;position:fixed;transform:translateY(100px)}.notification.show{opacity:1;transform:translateY(0)}.notification-success{border-left-color:var(--color-success)}.notification-error{border-left-color:var(--color-error)}.notification-warning{border-left-color:var(--color-warning)}.notification-info{border-left-color:var(--color-info)}.hidden{display:none}.notification-empty{text-align:center;padding:16px}.pdf-render-offscreen{color:#000;z-index:-1;background:#fff;width:800px;position:absolute;top:-9999px;left:-9999px}.loading-screen{z-index:9999;background:var(--color-bg-primary);justify-content:center;align-items:center;transition:opacity .5s,visibility .5s;display:flex;position:fixed;inset:0}.loading-screen.fade-out{opacity:0;visibility:hidden;pointer-events:none}.loading-screen-content{align-items:center;gap:var(--spacing-xl);flex-direction:column;animation:.4s ease-out fadeIn;display:flex}.loading-logo{align-items:center;gap:var(--spacing-md);display:flex}.loading-logo svg{animation:2s ease-in-out infinite loadingPulse}.loading-brand{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);background:linear-gradient(135deg, var(--color-accent-primary), var(--color-accent-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.loading-bar-track{background:var(--color-bg-tertiary);border-radius:var(--radius-full,9999px);width:240px;height:4px;overflow:hidden}.loading-bar-fill{border-radius:var(--radius-full,9999px);background:linear-gradient(90deg, var(--color-accent-primary), var(--color-accent-secondary));width:40%;height:100%;animation:1.2s ease-in-out infinite loadingShimmer}.loading-status{font-size:var(--font-size-sm);color:var(--color-text-tertiary);font-weight:var(--font-weight-medium);letter-spacing:.3px}@keyframes loadingShimmer{0%{transform:translate(-150%)}to{transform:translate(400%)}}@keyframes loadingPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}
.app-container{background:var(--color-bg-primary);min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--color-bg-secondary);border-right:1px solid var(--color-border);z-index:100;flex-direction:column;height:100vh;display:flex;position:fixed;top:0;left:0}.sidebar-header{padding:var(--spacing-xl) var(--spacing-lg);border-bottom:1px solid var(--color-border)}.logo{align-items:center;gap:var(--spacing-md);display:flex}.sidebar-nav{padding:var(--spacing-md) var(--spacing-lg);flex-direction:column;flex:1;gap:2px;display:flex;overflow-y:auto}.nav-section-label{font-size:10px;font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:1.2px;color:var(--color-text-tertiary);padding:var(--spacing-lg) var(--spacing-lg) var(--spacing-xs);margin-top:var(--spacing-xs)}.nav-section-label:first-child{margin-top:0}.nav-item{align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);transition:all var(--transition-base);display:flex;position:relative;overflow:hidden}.nav-item:before{content:"";background:var(--color-accent-primary);width:3px;transition:transform var(--transition-base);position:absolute;top:0;bottom:0;left:0;transform:scaleY(0)}.nav-item:hover{background:var(--color-surface);color:var(--color-text-primary)}.nav-item.active{background:var(--color-accent-glow);color:var(--color-accent-primary)}.nav-item.active:before{transform:scaleY(1)}.nav-item svg{flex-shrink:0}.main-content{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.topbar{height:var(--topbar-height);background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);padding:0 var(--spacing-xl);z-index:50;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--color-text-primary);justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.topbar-left h1{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold)}.topbar-right{align-items:center;gap:var(--spacing-md);display:flex}.notification-wrapper{position:relative}.notification-badge{color:#fff;font-size:10px;font-weight:var(--font-weight-bold);pointer-events:none;background:#ff5252;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;display:flex;position:absolute;top:-2px;right:-2px}.notification-panel{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);z-index:200;width:360px;max-height:400px;position:absolute;top:calc(100% + 8px);right:0;overflow-y:auto;box-shadow:0 16px 48px #0000004d}.notification-panel-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.notification-panel-header h3{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);margin:0}.btn-link{color:var(--color-accent-primary);font-size:var(--font-size-xs);cursor:pointer;background:0 0;border:none;padding:0}.notification-item{gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);cursor:pointer;transition:background var(--transition-base);border-bottom:1px solid var(--color-border);display:flex}.notification-item:last-child{border-bottom:none}.notification-item:hover{background:var(--color-surface)}.notification-item.unread{border-left:3px solid var(--color-accent-primary);background:#1e3a8a0d}.notification-icon{flex-shrink:0;margin-top:2px;font-size:18px}.notification-body{flex:1;min-width:0}.notification-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:2px}.notification-message{font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;overflow:hidden}.notification-time{color:var(--color-text-tertiary);font-size:10px}.user-profile{align-items:center;gap:var(--spacing-sm);cursor:pointer;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);transition:background var(--transition-base);display:flex}.user-profile:hover{background:var(--color-surface)}.user-name{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.user-dropdown{top:calc(var(--topbar-height) - 8px);right:var(--spacing-xl);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);z-index:200;min-width:160px;position:absolute;overflow:hidden;box-shadow:0 8px 32px #0000004d}.dropdown-item{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-sm);color:var(--color-text-secondary);transition:all var(--transition-base);display:block}.dropdown-item:hover{background:var(--color-surface);color:var(--color-text-primary)}.empty-state{padding:var(--spacing-xxl) var(--spacing-xl);text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:400px;display:flex}.empty-state h3{font-size:var(--font-size-xl);color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.empty-state p{color:var(--color-text-secondary);font-size:var(--font-size-md)}.avatar{background:linear-gradient(135deg, var(--color-accent-primary), var(--color-accent-secondary));width:40px;height:40px;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-bg-primary);border-radius:50%;justify-content:center;align-items:center;display:flex}.content-area{padding:var(--spacing-xl);animation:fadeIn var(--transition-base) ease-out;flex:1;min-width:0;overflow:hidden auto}.metrics-grid{gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl);grid-template-columns:repeat(auto-fit,minmax(250px,1fr));display:grid}.metric-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--transition-base);position:relative;overflow:hidden}.metric-card:before{content:"";background:linear-gradient(90deg, var(--color-accent-primary), var(--color-accent-secondary));transform-origin:0;height:3px;transition:transform var(--transition-base);position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.metric-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.metric-card:hover:before{transform:scaleX(1)}.metric-header{margin-bottom:var(--spacing-md);justify-content:space-between;align-items:center;display:flex}.metric-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.metric-icon{border-radius:var(--radius-md);background:var(--color-accent-glow);width:40px;height:40px;color:var(--color-accent-primary);justify-content:center;align-items:center;display:flex}.metric-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.metric-change{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.metric-change.positive{color:var(--color-success)}.metric-change.negative{color:var(--color-error)}.projects-section{margin-top:var(--spacing-2xl)}.section-header{margin-bottom:var(--spacing-lg);justify-content:space-between;align-items:center;display:flex}.section-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold)}.projects-grid{gap:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));display:grid}.project-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-base);cursor:pointer;overflow:hidden}.project-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-xl);transform:translateY(-4px)}.project-image{object-fit:cover;background:var(--color-bg-elevated);width:100%;height:180px;position:relative;overflow:hidden}.project-content{padding:var(--spacing-lg)}.project-header{margin-bottom:var(--spacing-md);justify-content:space-between;align-items:start;display:flex}.project-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-xs)}.project-client{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.project-meta{gap:var(--spacing-sm);margin-top:var(--spacing-md);flex-direction:column;display:flex}.project-phase{align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-text-secondary);display:flex}.project-phase svg{color:var(--color-accent-primary)}.client-list{gap:var(--spacing-md);flex-direction:column;display:flex}.client-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--transition-base);justify-content:space-between;align-items:center;display:flex}.client-item:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-md)}.client-info{align-items:center;gap:var(--spacing-lg);display:flex}.client-avatar{background:var(--color-accent-glow);width:48px;height:48px;font-weight:var(--font-weight-semibold);color:var(--color-accent-primary);border-radius:50%;justify-content:center;align-items:center;display:flex}.client-details h3{font-size:var(--font-size-base);margin-bottom:var(--spacing-xs)}.client-meta{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.client-actions{gap:var(--spacing-sm);display:flex}@media (max-width:768px){.sidebar{transform:translate(-100%)}.main-content{margin-left:0}.metrics-grid,.projects-grid{grid-template-columns:1fr}}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;padding:var(--spacing-lg);animation:fadeIn var(--transition-base) ease-out;background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:500px;max-height:90vh;box-shadow:var(--shadow-xl);animation:slideIn var(--transition-base) ease-out;overflow-y:auto}.modal-xl{width:95%;max-width:1100px}.modal-header{padding:var(--spacing-xl);border-bottom:1px solid var(--color-border);background:var(--color-bg-secondary);z-index:10;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.modal-header h2{margin:0}.modal-body{padding:var(--spacing-xl)}.modal-footer{gap:var(--spacing-md);margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border);justify-content:flex-end;display:flex}.form-group{gap:var(--spacing-sm);flex-direction:column;display:flex}.form-group label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.form-group input,.form-group select,.form-group textarea{padding:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:inherit;font-size:var(--font-size-base);transition:all var(--transition-base)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 3px var(--color-accent-glow);outline:none}.form-group input[type=file]{padding:var(--spacing-sm);cursor:pointer}.form-group textarea{resize:vertical;min-height:80px}.btn-sm{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-sm)}.photo-preview{gap:var(--spacing-md);margin-top:var(--spacing-md);grid-template-columns:repeat(auto-fill,minmax(100px,1fr));display:grid}.photo-preview-item{border-radius:var(--radius-md);background:var(--color-surface);border:1px solid var(--color-border);position:relative;overflow:hidden}.photo-preview-item img{object-fit:cover;width:100%;height:100px;display:block}.photo-name{padding:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;display:block;overflow:hidden}.project-detail-grid{gap:var(--spacing-xl);grid-template-columns:1fr 1fr;display:grid}.detail-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.detail-section h3{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.detail-item.full-width{align-items:flex-start;gap:var(--spacing-sm);flex-direction:column}.detail-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.section-header-small{margin-bottom:var(--spacing-lg);justify-content:space-between;align-items:center;display:flex}.section-header-small h3{border:none;margin:0;padding:0}.expense-summary{gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--color-bg-elevated);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);flex-direction:column;display:flex}.expense-stat{justify-content:space-between;align-items:center;display:flex}.expense-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.expense-value{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.expense-list{gap:var(--spacing-sm);flex-direction:column;display:flex}.expense-item{padding:var(--spacing-md);background:var(--color-bg-elevated);border-radius:var(--radius-md);transition:all var(--transition-fast);justify-content:space-between;align-items:center;display:flex}.expense-item:hover{background:var(--color-surface-hover)}.expense-description{font-size:var(--font-size-base);color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.expense-date{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:var(--spacing-xs)}.expense-amount{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-accent-primary)}.photo-gallery{gap:var(--spacing-md);grid-template-columns:repeat(auto-fill,minmax(150px,1fr));display:grid}.gallery-item{border-radius:var(--radius-md);background:var(--color-bg-elevated);border:1px solid var(--color-border);transition:all var(--transition-base);cursor:pointer;position:relative;overflow:hidden}.gallery-item:hover{box-shadow:var(--shadow-lg);transform:scale(1.05)}.gallery-item img{object-fit:cover;width:100%;height:150px;display:block}.notification{bottom:var(--spacing-xl);right:var(--spacing-xl);padding:var(--spacing-md) var(--spacing-lg);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-xl);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);z-index:2000;opacity:0;transition:all var(--transition-base);position:fixed;transform:translateY(20px)}.notification.show{opacity:1;transform:translateY(0)}.notification-success{border-left:4px solid var(--color-success);color:var(--color-success)}.notification-error{border-left:4px solid var(--color-error);color:var(--color-error)}.notification-info{border-left:4px solid var(--color-info);color:var(--color-info)}.financial-overview{margin-bottom:var(--spacing-2xl)}.financial-grid{gap:var(--spacing-lg);grid-template-columns:repeat(4,1fr);display:grid}.financial-card{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--transition-base);position:relative;overflow:hidden}.financial-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.financial-header{margin-bottom:var(--spacing-md);justify-content:space-between;align-items:center;display:flex}.financial-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.financial-icon{border-radius:var(--radius-md);background:var(--color-surface);width:32px;height:32px;color:var(--color-text-secondary);justify-content:center;align-items:center;display:flex}.financial-value{font-size:24px;font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.financial-detail{font-size:var(--font-size-xs);margin-bottom:var(--spacing-md);justify-content:space-between;display:flex}.detail-label{color:var(--color-text-tertiary)}.detail-value{color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.financial-progress{background:var(--color-surface);border-radius:2px;height:4px;overflow:hidden}.project-health-badge{top:var(--spacing-md);right:var(--spacing-md);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:var(--color-text-primary);background:#0009;border:1px solid #ffffff1a;align-items:center;gap:6px;padding:4px 8px;display:flex;position:absolute}.health-on-track{color:var(--color-success);border-color:rgba(var(--color-success-rgb), .3)}.health-at-risk{color:var(--color-warning);border-color:rgba(var(--color-warning-rgb), .3)}.health-delayed{color:var(--color-error);border-color:rgba(var(--color-error-rgb), .3)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.text-info{color:var(--color-info)}.text-primary{color:var(--color-primary)}.pipeline-page{gap:var(--spacing-lg);box-sizing:border-box;flex-direction:column;width:100%;max-width:100%;height:calc(100vh - 140px);display:flex}.pipeline-summary-bar{gap:var(--spacing-sm);grid-template-columns:repeat(4,1fr);width:100%;display:grid}.pipeline-summary-card{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-sm) var(--spacing-md);transition:all var(--transition-base);position:relative;overflow:hidden}.pipeline-summary-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.pipeline-summary-card:before{content:"";background:linear-gradient(90deg, var(--color-accent-primary), var(--color-accent-secondary));opacity:.7;height:3px;position:absolute;top:0;left:0;right:0}.pipeline-summary-card .summary-label{font-size:var(--font-size-xs);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-xs)}.pipeline-summary-card .summary-value{font-size:1.2rem;font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1.2}.pipeline-summary-card .summary-sub{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:2px}.pipeline-toolbar{align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.pipeline-filters{align-items:center;gap:var(--spacing-xs);flex:1;min-width:0;display:flex}.pipeline-filter-select{font-size:11px;font-family:var(--font-family);color:var(--color-text-secondary);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;appearance:none;transition:all var(--transition-fast);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'%3E%3Cpath d='M2 4L5 7L8 4' stroke='%239CA3AF' stroke-width='1.5' stroke-linecap='round' fill='none'/%3E%3C/svg%3E");background-position:right 6px center;background-repeat:no-repeat;outline:none;max-width:130px;padding:5px 24px 5px 8px}.pipeline-filter-select:hover{border-color:var(--color-border-hover)}.pipeline-filter-select:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 2px var(--color-accent-glow)}.pipeline-view-toggle{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;overflow:hidden}.pipeline-view-btn{font-size:11px;font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;padding:5px 10px}.pipeline-view-btn:hover{color:var(--color-text-primary);background:var(--color-surface-hover)}.pipeline-view-btn.active{color:#fff;background:linear-gradient(135deg, var(--color-accent-primary), var(--color-accent-secondary))}.pipeline-add-lead-btn{font-size:12px;font-weight:var(--font-weight-semibold);color:#fff;background:linear-gradient(135deg, var(--color-accent-primary), var(--color-accent-secondary));border-radius:var(--radius-md);cursor:pointer;box-shadow:var(--shadow-sm);transition:all var(--transition-base);white-space:nowrap;border:none;flex-shrink:0;align-items:center;gap:4px;padding:6px 12px;display:inline-flex}.pipeline-add-lead-btn:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.pipeline-board{gap:var(--spacing-sm);padding-bottom:var(--spacing-sm);scroll-behavior:smooth;flex:1;min-height:0;display:flex;overflow-x:auto}.pipeline-board::-webkit-scrollbar{height:6px}.pipeline-board::-webkit-scrollbar-thumb{background:var(--color-bg-tertiary);border-radius:3px}.pipeline-column{background:var(--color-bg-elevated);border-radius:var(--radius-lg);border:1px solid var(--color-border);min-width:200px;max-width:320px;transition:border-color var(--transition-fast);flex-direction:column;flex:1 1 0;max-height:100%;display:flex}.pipeline-column[data-stage=LEAD]{border-top:3px solid #9ca3af}.pipeline-column[data-stage=PROPOSAL]{border-top:3px solid #3b82f6}.pipeline-column[data-stage=NEGOTIATION]{border-top:3px solid #f59e0b}.pipeline-column[data-stage=APPROVED]{border-top:3px solid #16a34a}.pipeline-column[data-stage=IN_PROGRESS]{border-top:3px solid #8b5cf6}.pipeline-column[data-stage=COMPLETED]{border-top:3px solid #059669}.column-header{padding:var(--spacing-md);border-bottom:1px solid var(--color-border);gap:var(--spacing-xs);background:inherit;z-index:10;border-radius:var(--radius-lg) var(--radius-lg) 0 0;flex-direction:column;display:flex;position:sticky;top:0}.column-header-top{justify-content:space-between;align-items:center;display:flex}.column-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-text-primary);text-transform:uppercase;letter-spacing:.03em;align-items:center;gap:6px;display:flex}.column-title .stage-icon{font-size:14px}.column-count{background:var(--color-surface-hover);border-radius:var(--radius-full,999px);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);padding:2px 8px}.column-financial{font-size:var(--font-size-xs);justify-content:space-between;align-items:center;display:flex}.column-total-value{font-weight:var(--font-weight-bold);color:var(--color-accent-primary)}.column-conversion{color:var(--color-text-tertiary);align-items:center;gap:2px;display:flex}.column-conversion svg{width:10px;height:10px}.column-content{padding:var(--spacing-sm);gap:var(--spacing-sm);min-height:80px;transition:background var(--transition-fast);flex-direction:column;flex:1;display:flex;overflow-y:auto}.column-content::-webkit-scrollbar{width:4px}.column-content::-webkit-scrollbar-thumb{background:var(--color-bg-tertiary);border-radius:2px}.column-content.drag-over{outline:2px dashed var(--color-accent-secondary);outline-offset:-2px;border-radius:0 0 var(--radius-lg) var(--radius-lg);background:#3b82f60a}.column-empty{padding:var(--spacing-xl) var(--spacing-md);color:var(--color-text-tertiary);font-size:var(--font-size-xs);text-align:center;justify-content:center;align-items:center;gap:var(--spacing-sm);flex-direction:column;display:flex}.column-empty svg{opacity:.3}.pipeline-card{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);cursor:grab;transition:all var(--transition-base);padding:14px;position:relative}.pipeline-card:hover{border-color:var(--color-accent-secondary);transform:translateY(-3px);box-shadow:0 8px 25px -5px #0000001a,0 4px 10px -5px #0000000a}.pipeline-card.dragging{opacity:.35;cursor:grabbing;box-shadow:var(--shadow-xl);transform:rotate(2deg)scale(.98)}.pipeline-card.high-value{border-left:3px solid var(--color-accent-primary)}.pipeline-card-top{align-items:center;gap:var(--spacing-sm);margin-bottom:10px;display:flex}.pipeline-card-avatar{background:linear-gradient(135deg, var(--color-accent-primary), var(--color-accent-secondary));color:#fff;width:32px;height:32px;font-size:11px;font-weight:var(--font-weight-bold);letter-spacing:.5px;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.pipeline-card-client-info{flex:1;min-width:0}.pipeline-card-client-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;line-height:1.3;overflow:hidden}.pipeline-card-company{color:var(--color-text-tertiary);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.pipeline-card-tags{flex-shrink:0;gap:4px;display:flex}.pipeline-tag{cursor:default;font-size:12px;line-height:1}.pipeline-card-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);align-items:center;gap:6px;margin-bottom:8px;line-height:1.4;display:flex}.pipeline-type-badge{border-radius:var(--radius-sm);color:var(--color-info);font-size:10px;font-weight:var(--font-weight-medium);white-space:nowrap;text-transform:uppercase;letter-spacing:.03em;background:#3b82f614;padding:1px 6px}.pipeline-card-value{font-size:1.25rem;font-weight:var(--font-weight-bold);color:var(--color-text-primary);letter-spacing:-.02em;margin-bottom:10px}.pipeline-card-action{background:var(--color-bg-secondary);border-radius:var(--radius-sm);font-size:var(--font-size-xs);align-items:center;gap:6px;margin-bottom:8px;padding:6px 8px;display:flex}.pipeline-card-action .action-icon{flex-shrink:0;font-size:12px}.pipeline-card-action .action-text{color:var(--color-text-secondary);font-weight:var(--font-weight-medium);flex:1}.pipeline-action-due{border-radius:var(--radius-full,999px);font-size:10px;font-weight:var(--font-weight-semibold);white-space:nowrap;padding:1px 6px}.pipeline-action-due.due-overdue{color:var(--color-error);background:#dc26261a}.pipeline-action-due.due-today{color:var(--color-warning);background:#f59e0b1a}.pipeline-action-due.due-upcoming{color:var(--color-success);background:#16a34a1a}.pipeline-card-bottom{color:var(--color-text-tertiary);justify-content:space-between;align-items:center;margin-bottom:8px;font-size:11px;display:flex}.pipeline-last-interaction{align-items:center;gap:4px;display:flex}.pipeline-health{border-radius:50%;flex-shrink:0;width:8px;height:8px}.pipeline-health.health-on-track{background:var(--color-success)}.pipeline-health.health-at-risk{background:var(--color-warning)}.pipeline-health.health-delayed{background:var(--color-error)}.pipeline-card-actions{opacity:0;transition:opacity var(--transition-fast);border-top:1px solid var(--color-border);gap:4px;margin-top:4px;padding-top:8px;display:flex}.pipeline-card:hover .pipeline-card-actions{opacity:1}.pipeline-ai-btn{font-size:10px;font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:var(--color-bg-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);text-align:center;white-space:nowrap;border:1px solid #0000;flex:1;padding:4px 6px}.pipeline-ai-btn:hover{color:var(--color-accent-primary);background:var(--color-accent-glow);border-color:var(--color-accent-secondary)}.pipeline-list-view{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);flex:1;overflow-y:auto}.pipeline-list-header{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border);background:var(--color-bg-secondary);z-index:5;grid-template-columns:2fr 1.2fr 1fr 1fr 1fr 1fr 100px;display:grid;position:sticky;top:0}.pipeline-list-row{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);border-bottom:1px solid var(--color-border);transition:background var(--transition-fast);cursor:pointer;grid-template-columns:2fr 1.2fr 1fr 1fr 1fr 1fr 100px;align-items:center;display:grid}.pipeline-list-row:hover{background:var(--color-surface-hover)}.pipeline-list-row:last-child{border-bottom:none}.pipeline-list-client{align-items:center;gap:var(--spacing-sm);display:flex}.pipeline-list-avatar{background:linear-gradient(135deg, var(--color-accent-primary), var(--color-accent-secondary));color:#fff;width:28px;height:28px;font-size:10px;font-weight:var(--font-weight-bold);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.pipeline-list-val{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.pipeline-list-stage{font-size:var(--font-size-xs);border-radius:var(--radius-full,999px);font-weight:var(--font-weight-medium);text-align:center;padding:2px 8px;display:inline-block}.pipeline-list-stage.stage-LEAD{color:#6b7280;background:#9ca3af1f}.pipeline-list-stage.stage-PROPOSAL{color:#3b82f6;background:#3b82f61a}.pipeline-list-stage.stage-NEGOTIATION{color:#f59e0b;background:#f59e0b1a}.pipeline-list-stage.stage-APPROVED{color:#16a34a;background:#16a34a1a}.pipeline-list-stage.stage-IN_PROGRESS{color:#8b5cf6;background:#8b5cf61a}.pipeline-list-stage.stage-COMPLETED{color:#059669;background:#0596691a}.pipeline-calendar-view{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md);flex:1;overflow-y:auto}.pipeline-calendar-header{margin-bottom:var(--spacing-md);justify-content:space-between;align-items:center;display:flex}.pipeline-calendar-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.pipeline-calendar-grid{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.pipeline-cal-day-header{text-align:center;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);padding:var(--spacing-sm);text-transform:uppercase}.pipeline-cal-day{border:1px solid var(--color-border);border-radius:var(--radius-sm);min-height:90px;font-size:var(--font-size-xs);transition:background var(--transition-fast);padding:6px;position:relative}.pipeline-cal-day:hover{background:var(--color-surface-hover)}.pipeline-cal-day.today{border-color:var(--color-accent-secondary);background:#3b82f60a}.pipeline-cal-day.other-month{opacity:.35}.pipeline-cal-day-num{font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);margin-bottom:4px}.pipeline-cal-day.today .pipeline-cal-day-num{color:var(--color-accent-secondary);font-weight:var(--font-weight-bold)}.pipeline-cal-event{white-space:nowrap;text-overflow:ellipsis;cursor:pointer;transition:opacity var(--transition-fast);border-radius:3px;margin-bottom:2px;padding:2px 4px;font-size:10px;overflow:hidden}.pipeline-cal-event:hover{opacity:.8}.pipeline-cal-event.event-lead{color:#6b7280;background:#9ca3af26}.pipeline-cal-event.event-proposal{color:#3b82f6;background:#3b82f61a}.pipeline-cal-event.event-negotiation{color:#d97706;background:#f59e0b1a}.pipeline-cal-event.event-approved{color:#16a34a;background:#16a34a1a}.pipeline-cal-event.event-milestone{color:#7c3aed;background:#8b5cf61f;border-left:2px solid #7c3aed}.pipeline-cal-event.event-done{opacity:.55;color:#16a34a;background:#16a34a14;text-decoration:line-through}.cal-event-icon{vertical-align:middle;margin-right:3px;font-size:6px}.pipeline-cal-legend{background:var(--color-bg-elevated);border-radius:var(--border-radius-md);border:1px solid var(--color-border);font-size:var(--font-size-xs);color:var(--color-text-secondary);align-items:center;gap:20px;margin-top:12px;padding:12px 16px;display:flex}.cal-legend-item{align-items:center;gap:6px;display:flex}.cal-legend-dot{font-size:10px}.cal-legend-dot.event-lead{color:#6b7280}.cal-legend-dot.event-milestone{color:#7c3aed}.cal-legend-dot.event-done{color:#16a34a;opacity:.55}.quick-lead-overlay{z-index:2000;background:#00000073;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.quick-lead-modal{background:var(--color-bg-elevated);border-radius:var(--radius-xl);padding:var(--spacing-xl);width:420px;max-width:90vw;box-shadow:var(--shadow-xl);animation:.25s ease-out fadeIn}.quick-lead-modal h3{margin-bottom:var(--spacing-lg);font-size:var(--font-size-lg);align-items:center;gap:var(--spacing-sm);display:flex}.quick-lead-modal .form-group{margin-bottom:var(--spacing-md)}.quick-lead-modal .form-group label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px;display:block}.quick-lead-modal input,.quick-lead-modal select{width:100%;font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast);outline:none;padding:8px 12px}.quick-lead-modal input:focus,.quick-lead-modal select:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 2px var(--color-accent-glow)}.quick-lead-footer{justify-content:flex-end;gap:var(--spacing-sm);margin-top:var(--spacing-lg);display:flex}.pipeline-automation-toast{bottom:80px;right:var(--spacing-xl);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-left:4px solid var(--color-accent-secondary);border-radius:var(--radius-md);padding:var(--spacing-md) var(--spacing-lg);box-shadow:var(--shadow-xl);z-index:2000;font-size:var(--font-size-sm);align-items:center;gap:var(--spacing-sm);max-width:400px;animation:.35s ease-out slideInRight;display:flex;position:fixed}@keyframes slideInRight{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.pipeline-automation-toast .auto-icon{font-size:20px}.pipeline-automation-toast .auto-text{flex:1}.pipeline-automation-toast .auto-title{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:2px}.pipeline-automation-toast .auto-desc{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.member-avatar-sm{background:var(--color-primary);color:#fff;border:2px solid var(--color-surface);border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;margin-left:-8px;font-size:10px;display:flex}.member-avatar-sm:first-child{margin-left:0}.team-grid{gap:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.team-card{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--transition-base)}.team-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.team-header{align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);display:flex}.team-avatar-lg{background:linear-gradient(135deg, var(--color-primary), var(--color-accent-secondary));color:#fff;width:48px;height:48px;font-size:18px;font-weight:var(--font-weight-bold);border-radius:50%;justify-content:center;align-items:center;display:flex}.team-info h3{font-size:var(--font-size-lg);color:var(--color-text-primary);margin:0}.team-role{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.team-stats{margin-bottom:var(--spacing-lg)}.stat-row{font-size:var(--font-size-sm);margin-bottom:var(--spacing-xs);color:var(--color-text-secondary);justify-content:space-between;display:flex}.stat-progress{background:var(--color-surface);border-radius:3px;height:6px;overflow:hidden}.subsection-title{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary);margin-bottom:var(--spacing-md)}.assignment-list{gap:var(--spacing-xs);margin-bottom:var(--spacing-lg);flex-direction:column;display:flex}.assignment-item{align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-surface);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-base);display:flex}.assignment-item:hover{background:var(--color-bg-base)}.assignment-name{white-space:nowrap;text-overflow:ellipsis;max-width:200px;overflow:hidden}.more-assignments{font-size:var(--font-size-xs);color:var(--color-text-tertiary);padding-left:var(--spacing-sm)}.team-skills{gap:var(--spacing-xs);flex-wrap:wrap;display:flex}.skill-tag{background:var(--color-surface);border-radius:var(--radius-full);color:var(--color-text-secondary);border:1px solid var(--color-border);padding:2px 8px;font-size:11px}.modal-tabs{gap:var(--spacing-lg);padding:0 var(--spacing-xl);border-bottom:1px solid var(--color-border);margin-bottom:var(--spacing-lg);display:flex;overflow-x:auto}.tab-btn{padding:var(--spacing-md) 0;color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;white-space:nowrap;transition:all var(--transition-base);background:0 0;border:none;border-bottom:2px solid #0000}.tab-btn:hover{color:var(--color-text-primary)}.tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.empty-state{padding:var(--spacing-2xl);text-align:center;background:var(--color-bg-base);border-radius:var(--radius-lg);border:1px dashed var(--color-border)}.tasks-list{gap:var(--spacing-sm);flex-direction:column;display:flex}.task-item{align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-base);display:flex}.task-item:hover{border-color:var(--color-border-hover)}.task-item.completed .task-title{color:var(--color-text-tertiary);text-decoration:line-through}.checkbox-wrapper input{cursor:pointer;width:18px;height:18px;accent-color:var(--color-primary)}.task-content{flex-direction:column;flex:1;display:flex}.task-title{font-size:var(--font-size-sm);color:var(--color-text-primary)}.task-due{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.files-list{gap:var(--spacing-md);grid-template-columns:repeat(auto-fill,minmax(250px,1fr));display:grid}.file-item{align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-base);display:flex}.file-item:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.file-icon{border-radius:var(--radius-md);background:rgba(var(--color-primary-rgb), .1);width:40px;height:40px;color:var(--color-primary);justify-content:center;align-items:center;display:flex}.file-info{flex:1;overflow:hidden}.file-name{font-size:var(--font-size-sm);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;overflow:hidden}.file-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.activity-feed{gap:var(--spacing-md);flex-direction:column;display:flex}.activity-item{gap:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border);display:flex}.activity-item:last-child{border-bottom:none}.activity-icon{background:var(--color-bg-base);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;display:flex}.activity-content{flex:1}.activity-text{font-size:var(--font-size-sm);color:var(--color-text-primary);margin-bottom:4px}.activity-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.project-team-list h3{margin-bottom:var(--spacing-md);font-size:var(--font-size-md);color:var(--color-text-secondary)}@media (max-width:1200px){.financial-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.financial-grid{grid-template-columns:1fr}.modal-content{border-radius:0;flex-direction:column;max-width:100%;height:100%;max-height:100vh;margin:0;display:flex}.modal-body{flex:1;overflow-y:auto}.form-grid,.project-detail-grid{grid-template-columns:1fr}.detail-section.full-width{grid-column:1}}.reports-container{padding-bottom:var(--spacing-xl)}.reports-header{margin-bottom:var(--spacing-xl)}.reports-stats{gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));display:grid}.report-stat-card{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);gap:var(--spacing-xs);flex-direction:column;display:flex}.stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.stat-value{font-size:2rem;font-weight:var(--font-weight-bold);color:var(--color-text-primary);font-family:var(--font-heading)}.stat-change{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.charts-grid-reports{gap:var(--spacing-lg);grid-template-columns:repeat(2,1fr);display:grid}.chart-card{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);flex-direction:column;display:flex}.chart-card.large{grid-column:span 2}.chart-header{margin-bottom:var(--spacing-lg);justify-content:space-between;align-items:center;display:flex}.chart-header h3{font-size:var(--font-size-md);color:var(--color-text-primary);margin:0}.chart-select{background:var(--color-bg-base);border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:var(--radius-sm);font-size:var(--font-size-xs);padding:4px 8px}.chart-container{width:100%;position:relative;overflow:hidden}@media (max-width:1024px){.charts-grid-reports{grid-template-columns:1fr}.chart-card.large{grid-column:1}}.lead-metrics-bar,.client-metrics-bar{gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);flex-wrap:wrap;display:flex}.mini-stat{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-lg) var(--spacing-xl);min-width:180px;transition:all var(--transition-base);box-shadow:var(--shadow-sm);flex-direction:column;gap:8px;display:flex;position:relative;overflow:hidden}.mini-stat:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary);transform:translateY(-4px)}.mini-stat:before{content:"";background:var(--color-primary);border-radius:4px 0 0 4px;width:4px;height:100%;position:absolute;top:0;left:0}.mini-stat:nth-child(2):before{background:#3b82f6}.mini-stat:nth-child(3):before{background:#10b981}.mini-stat:nth-child(4):before{background:#f59e0b}.mini-stat-value{color:var(--color-text-primary);font-size:2rem;font-weight:800;font-family:var(--font-heading);line-height:1}.mini-stat-label{color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:1.2px;font-size:.7rem;font-weight:700}.project-detail-grid{gap:var(--spacing-2xl);margin-top:var(--spacing-xl);grid-template-columns:repeat(2,1fr);display:grid}.detail-section h3{font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:1px;color:var(--color-text-tertiary);margin-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-border);padding-bottom:var(--spacing-sm)}.detail-item{padding:var(--spacing-md) 0;border-bottom:1px solid var(--color-border-subtle);justify-content:space-between;align-items:center;display:flex}.detail-item:last-child{border-bottom:none}.detail-label{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.detail-item strong,.detail-item span:not(.detail-label){font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.finance-chart-container{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--border-radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-xl);min-height:250px}.finance-table{border-collapse:separate;border-spacing:0;width:100%}.finance-table th{text-align:left;padding:var(--spacing-md);font-size:var(--font-size-xs);text-transform:uppercase;color:var(--color-text-tertiary);border-bottom:1px solid var(--color-border)}.finance-table tr:last-child td{border-bottom:none}.ai-generating{position:relative;overflow:hidden}.ai-generating:after{content:"";background:linear-gradient(90deg,#0000,#d4af371a,#0000);width:200%;height:100%;animation:2s infinite ai-shine;position:absolute;top:0;left:-100%}@keyframes ai-shine{to{transform:translate(100%)}}.typing-cursor{background:var(--color-primary);vertical-align:middle;width:2px;height:1em;margin-left:2px;animation:1s infinite blink;display:inline-block}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.client-profile-modal{grid-template-columns:240px 1fr;min-height:600px;display:grid}.profile-sidebar{background:var(--color-bg-secondary);border-right:1px solid var(--color-border);padding:var(--spacing-lg) 0}.profile-nav-item{align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);width:100%;color:var(--color-text-secondary);font-weight:var(--font-weight-medium);transition:all var(--transition-fast);display:flex}.profile-nav-item:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.profile-nav-item.active{background:var(--color-bg-elevated);color:var(--color-accent-primary);border-right:3px solid var(--color-accent-primary)}.profile-content{padding:var(--spacing-xl);max-height:80vh;overflow-y:auto}.timeline{padding-left:var(--spacing-xl);position:relative}.timeline:before{content:"";background:var(--color-border);width:2px;position:absolute;top:0;bottom:0;left:7px}.timeline-item{margin-bottom:var(--spacing-lg);position:relative}.timeline-dot{background:var(--color-accent-primary);border:3px solid var(--color-bg-elevated);z-index:1;border-radius:50%;width:16px;height:16px;position:absolute;top:4px;left:-23px}.timeline-content{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);box-shadow:var(--shadow-sm)}.timeline-time{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-bottom:4px}.progress-container{background:var(--color-bg-secondary);width:100%;height:8px;margin:var(--spacing-sm) 0;border-radius:4px;overflow:hidden}.progress-bar{background:var(--color-accent-primary);height:100%;transition:width .5s ease-out}.finance-table{border-collapse:collapse;width:100%}.finance-table th{text-align:left;padding:var(--spacing-md);border-bottom:2px solid var(--color-border);font-size:var(--font-size-xs);color:var(--color-text-tertiary);text-transform:uppercase}.finance-table td{padding:var(--spacing-md);border-bottom:1px solid var(--color-border);font-size:var(--font-size-sm)}.finance-table tr:hover{background:var(--color-bg-secondary)}.contractor-rating{margin:var(--spacing-sm) 0}.stars{color:var(--color-accent-primary);font-size:var(--font-size-md)}.rating-value{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-left:4px}.ai-container{gap:var(--spacing-xl);padding:var(--spacing-lg);height:calc(100vh - var(--topbar-height) - 60px);grid-template-columns:1fr 280px;display:grid}.ai-chat-panel{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);flex-direction:column;display:flex;overflow:hidden}.ai-chat-header{align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);display:flex}.ai-chat-header h3{font-size:var(--font-size-md);margin:0}.ai-avatar{background:var(--color-accent-glow);border-radius:var(--radius-md);justify-content:center;align-items:center;width:40px;height:40px;font-size:28px;display:flex}.ai-chat-messages{padding:var(--spacing-lg);gap:var(--spacing-md);flex-direction:column;flex:1;display:flex;overflow-y:auto}.ai-message{gap:var(--spacing-md);max-width:85%;display:flex}.ai-message.user{flex-direction:row-reverse;align-self:flex-end}.ai-message-avatar{flex-shrink:0;font-size:20px}.ai-message-content{background:var(--color-surface);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-lg);font-size:var(--font-size-sm);line-height:1.6}.ai-message-content p{margin:4px 0}.ai-message-content ul{padding-left:var(--spacing-lg);margin:4px 0}.ai-message-content li{font-size:var(--font-size-sm);margin:4px 0}.ai-message.user .ai-message-content{background:var(--color-accent-glow);color:var(--color-accent-primary)}.ai-chat-input{gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-border);display:flex}.ai-chat-input .form-input{flex:1}.ai-quick-actions{gap:var(--spacing-sm);flex-direction:column;display:flex}.ai-quick-actions h3{font-size:var(--font-size-md);margin-bottom:var(--spacing-sm)}.ai-action-btn{width:100%;padding:var(--spacing-md) var(--spacing-lg);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);text-align:left;cursor:pointer;transition:all var(--transition-base);display:block}.ai-action-btn:hover{background:var(--color-surface);color:var(--color-text-primary);border-color:var(--color-accent-primary)}.data-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.data-table th{text-align:left;padding:var(--spacing-sm) var(--spacing-md);color:var(--color-text-tertiary);font-weight:var(--font-weight-medium);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--color-border)}.data-table td{padding:var(--spacing-sm) var(--spacing-md);color:var(--color-text-secondary);border-bottom:1px solid var(--color-border)}.data-table tr:hover td{background:var(--color-surface)}.financials-container{padding:var(--spacing-lg)}.invoice-table{overflow-x:auto}@media (max-width:768px){.ai-container{grid-template-columns:1fr;height:auto}}.clients-container{padding:var(--spacing-lg)}.client-toolbar{justify-content:space-between;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);flex-wrap:wrap;display:flex}.search-bar{align-items:center;gap:var(--spacing-sm);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:0 var(--spacing-md);min-width:240px;display:flex}.search-bar svg{color:var(--color-text-tertiary);flex-shrink:0}.search-bar .form-input{background:0 0;border:none;padding-left:0}.filter-group{gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.filter-select{min-width:140px;font-size:var(--font-size-sm)}.client-tags{flex-wrap:wrap;gap:4px;margin-top:4px;display:flex}.client-stats-inline{gap:var(--spacing-xl);align-items:center;display:flex}.client-stat{flex-direction:column;align-items:center;gap:2px;display:flex}.stat-num{font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.stat-lbl{color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px;font-size:10px}.avatar-lg{border-radius:var(--radius-md);background:var(--color-accent-glow);width:48px;height:48px;color:var(--color-accent-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-lg);flex-shrink:0;justify-content:center;align-items:center;display:flex}.comm-item{gap:var(--spacing-md);padding:var(--spacing-md);border-left:2px solid var(--color-border);margin-left:var(--spacing-md);display:flex;position:relative}.comm-item:before{content:"";left:-6px;top:var(--spacing-md);background:var(--color-accent-primary);border:2px solid var(--color-bg-primary);border-radius:50%;width:10px;height:10px;position:absolute}.comm-icon{flex-shrink:0;font-size:20px}.comm-subject{font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:4px}.comm-meta{gap:var(--spacing-sm);font-size:var(--font-size-xs);color:var(--color-text-tertiary);flex-wrap:wrap;align-items:center;display:flex}.form-grid{gap:var(--spacing-md);grid-template-columns:1fr 1fr;display:grid}.form-group.full-width{grid-column:1/-1}.modal-large{max-width:800px}.source-analytics{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg)}@media (max-width:768px){.client-toolbar{flex-direction:column;align-items:stretch}.client-stats-inline{display:none}.form-grid{grid-template-columns:1fr}}.project-detail-page{animation:.2s ease-out fadeIn}.pdp-header{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-xl);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:var(--spacing-md);flex-wrap:wrap;display:flex}.pdp-header-left{align-items:center;gap:var(--spacing-lg);flex:1;min-width:0;display:flex}.pdp-back-btn{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;flex-shrink:0;display:flex}.pdp-back-btn:hover{background:var(--color-bg-elevated);color:var(--color-text-primary);border-color:var(--color-border-hover)}.pdp-title-block{min-width:0}.pdp-title-block h1{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;margin:0;overflow:hidden}.pdp-title-block .pdp-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;overflow:hidden}.pdp-header-badges{align-items:center;gap:var(--spacing-sm);flex-shrink:0;display:flex}.pdp-header-actions{gap:var(--spacing-sm);flex-shrink:0;display:flex}.pdp-stats-row{gap:var(--spacing-md);margin-bottom:var(--spacing-xl);grid-template-columns:repeat(auto-fit,minmax(140px,1fr));display:grid}.pdp-stat-pill{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md) var(--spacing-lg);transition:all var(--transition-base);flex-direction:column;gap:4px;display:flex;position:relative;overflow:hidden}.pdp-stat-pill:before{content:"";background:linear-gradient(90deg, var(--color-accent-primary), var(--color-accent-secondary));transform-origin:0;height:3px;transition:transform .3s;position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.pdp-stat-pill:hover:before{transform:scaleX(1)}.pdp-stat-pill:hover{border-color:var(--color-border-hover);transform:translateY(-2px)}.pdp-stat-label{font-size:var(--font-size-xs);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px;font-weight:var(--font-weight-medium)}.pdp-stat-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.pdp-stat-sub{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.pdp-tabs{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--spacing-xl);gap:4px;padding:4px;display:flex;overflow-x:auto}.pdp-tab-btn{min-width:90px;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;text-align:center;background:0 0;border:none;flex:1}.pdp-tab-btn:hover{background:var(--color-bg-elevated);color:var(--color-text-primary)}.pdp-tab-btn.active{background:var(--color-accent-primary);color:#fff;box-shadow:0 2px 8px #3b82f659}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.3s forwards fadeIn}.typing-cursor:after{content:"|";animation:1s infinite blink}.invoice-document{color:#1a1a1a;font-family:Inter,sans-serif}.invoice-firm-info h2{letter-spacing:-1px;font-weight:800}.client-profile-page{margin:calc(var(--spacing-xl) * -1);background:var(--color-background);min-height:calc(100vh - 80px)}.client-profile-container{min-height:inherit;background:var(--color-surface);grid-template-columns:280px 1fr;display:grid}.client-profile-container .profile-sidebar{border-right:1px solid var(--color-border);background:var(--color-surface-subtle);padding:var(--spacing-xl) 0;flex-direction:column;display:flex}.client-profile-container .profile-content{padding:var(--spacing-2xl);max-height:calc(100vh - 80px);overflow-y:auto}.client-profile-modal{height:100%;display:flex}@media (max-width:1024px){.client-profile-container{grid-template-columns:1fr}.client-profile-container .profile-sidebar{border-right:none;border-bottom:1px solid var(--color-border)}}.pdp-tab-content{animation:.15s ease-out fadeIn}.pdp-overview-grid{gap:var(--spacing-lg);grid-template-columns:1fr 1fr;display:grid}@media (max-width:900px){.pdp-overview-grid{grid-template-columns:1fr}}.pdp-info-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.pdp-info-card h3{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border);align-items:center;gap:var(--spacing-sm);display:flex}.pdp-info-card h3 svg{color:var(--color-accent-primary)}.pdp-kv-row{padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-border);font-size:var(--font-size-sm);justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);display:flex}.pdp-kv-row:last-child{border-bottom:none}.pdp-kv-label{color:var(--color-text-secondary);flex-shrink:0}.pdp-kv-value{color:var(--color-text-primary);font-weight:var(--font-weight-medium);text-align:right}.pdp-phase-timeline{margin-top:var(--spacing-md);flex-wrap:wrap;gap:4px;display:flex}.pdp-phase-step{min-width:60px;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);background:var(--color-bg-elevated);border:1px solid var(--color-border);color:var(--color-text-tertiary);text-align:center;transition:all var(--transition-base);flex:1;font-size:10px}.pdp-phase-step.active{background:var(--color-accent-glow);border-color:var(--color-accent-primary);color:var(--color-accent-primary);font-weight:var(--font-weight-semibold)}.pdp-phase-step.done{border-color:var(--color-success);color:var(--color-success);background:#22c55e1a}.pdp-happening-now{border:1px solid var(--color-accent-primary);border-radius:var(--radius-lg);padding:var(--spacing-lg);background:linear-gradient(135deg,#3b82f614 0%,#8b5cf60d 100%);grid-column:1/-1}.pdp-happening-now h3{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-accent-primary);margin-bottom:var(--spacing-md);align-items:center;gap:var(--spacing-sm);display:flex}.pdp-happening-now h3:before{content:"";background:var(--color-accent-primary);border-radius:50%;width:8px;height:8px;animation:2s infinite pulse}.pdp-happening-stats{gap:var(--spacing-xl);flex-wrap:wrap;display:flex}.pdp-happening-stat{flex-direction:column;display:flex}.pdp-happening-stat .h-val{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.pdp-happening-stat .h-lbl{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.pdp-task-header{margin-bottom:var(--spacing-lg);justify-content:space-between;align-items:center;display:flex}.pdp-task-header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.pdp-kanban{gap:var(--spacing-lg);grid-template-columns:repeat(3,1fr);align-items:start;display:grid}@media (max-width:800px){.pdp-kanban{grid-template-columns:1fr}}.pdp-kanban-col{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md);min-height:300px}.pdp-kanban-col-header{padding:var(--spacing-sm) var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-sm);border-bottom:2px solid;justify-content:space-between;align-items:center;display:flex}.pdp-kanban-col-header.todo{border-color:var(--color-text-tertiary)}.pdp-kanban-col-header.inprogress{border-color:var(--color-warning)}.pdp-kanban-col-header.done{border-color:var(--color-success)}.pdp-kanban-col-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);align-items:center;gap:var(--spacing-sm);display:flex}.pdp-kanban-col-title .col-dot{border-radius:50%;width:8px;height:8px}.col-dot.todo{background:var(--color-text-tertiary)}.col-dot.inprogress{background:var(--color-warning)}.col-dot.done{background:var(--color-success)}.pdp-kanban-count{font-size:var(--font-size-xs);background:var(--color-bg-elevated);border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:99px;padding:2px 8px}.pdp-task-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-sm);transition:all var(--transition-base);cursor:default}.pdp-task-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.pdp-task-card-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--spacing-sm);line-height:1.4}.pdp-task-card-meta{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:4px;display:flex}.pdp-task-assignee{font-size:var(--font-size-xs);color:var(--color-text-secondary);align-items:center;gap:4px;display:flex}.pdp-task-assignee-avatar{background:var(--color-accent-glow);width:20px;height:20px;color:var(--color-accent-primary);font-size:9px;font-weight:var(--font-weight-bold);border-radius:50%;justify-content:center;align-items:center;display:flex}.pdp-task-due{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.pdp-task-due.overdue{color:var(--color-error)}.priority-badge{font-size:10px;font-weight:var(--font-weight-semibold);border-radius:99px;padding:2px 6px}.priority-high{color:var(--color-error);background:#ef444426}.priority-medium{color:var(--color-warning);background:#f59e0b26}.priority-low{color:var(--color-success);background:#22c55e1f}.pdp-kanban-add-btn{width:100%;padding:var(--spacing-sm);border:1px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-tertiary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);margin-top:var(--spacing-sm);justify-content:center;align-items:center;gap:var(--spacing-xs);background:0 0;display:flex}.pdp-kanban-add-btn:hover{border-color:var(--color-accent-primary);color:var(--color-accent-primary);background:var(--color-accent-glow)}.pdp-budget-summary{gap:var(--spacing-md);margin-bottom:var(--spacing-xl);grid-template-columns:repeat(auto-fit,minmax(160px,1fr));display:grid}.pdp-budget-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.pdp-budget-card-label{font-size:var(--font-size-xs);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-sm)}.pdp-budget-card-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.pdp-budget-card-sub{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:4px}.pdp-budget-bar-wrap{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.pdp-budget-bar-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-md);justify-content:space-between;display:flex}.pdp-budget-bar-track{background:var(--color-bg-elevated);border-radius:99px;height:12px;position:relative;overflow:hidden}.pdp-budget-bar-fill{border-radius:99px;height:100%;transition:width 1s ease-out;position:relative}.pdp-budget-bar-fill:after{content:"";background:#fff6;border-radius:99px;width:4px;animation:2s infinite shimmer;position:absolute;top:0;bottom:0;right:0}.pdp-budget-bar-fill.safe{background:linear-gradient(90deg,#22c55e,#4ade80)}.pdp-budget-bar-fill.warning{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.pdp-budget-bar-fill.danger{background:linear-gradient(90deg,#ef4444,#f87171)}@keyframes shimmer{0%,to{opacity:.4}50%{opacity:1}}.pdp-budget-bar-pct{text-align:right;font-size:var(--font-size-xs);margin-top:var(--spacing-sm);font-weight:var(--font-weight-semibold)}.pdp-budget-bar-pct.safe{color:var(--color-success)}.pdp-budget-bar-pct.warning{color:var(--color-warning)}.pdp-budget-bar-pct.danger{color:var(--color-error)}.pdp-budget-grid{gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);grid-template-columns:1fr 1fr;display:grid}@media (max-width:900px){.pdp-budget-grid{grid-template-columns:1fr}}.pdp-cat-breakdown{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.pdp-cat-breakdown h3{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-border);padding-bottom:var(--spacing-md)}.pdp-cat-row{align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-border);display:flex}.pdp-cat-row:last-child{border-bottom:none}.pdp-cat-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.pdp-cat-name{font-size:var(--font-size-sm);color:var(--color-text-secondary);flex:1}.pdp-cat-bar-track{background:var(--color-bg-elevated);border-radius:99px;width:80px;height:6px;overflow:hidden}.pdp-cat-bar-fill{border-radius:99px;height:100%;transition:width .8s ease-out}.pdp-cat-amount{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);text-align:right;min-width:80px}.pdp-expense-ledger{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.pdp-expense-ledger-header{margin-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-border);padding-bottom:var(--spacing-md);justify-content:space-between;align-items:center;display:flex}.pdp-expense-ledger h3{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold)}.pdp-expense-row{align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-border);font-size:var(--font-size-sm);display:flex}.pdp-expense-row:last-child{border-bottom:none}.pdp-expense-date{color:var(--color-text-tertiary);flex-shrink:0;min-width:80px}.pdp-expense-desc{color:var(--color-text-primary);flex:1}.pdp-expense-cat-badge{background:var(--color-accent-glow);color:var(--color-accent-primary);border-radius:99px;flex-shrink:0;padding:2px 8px;font-size:10px}.pdp-expense-amount{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);text-align:right;min-width:80px}.pdp-contractor-payments{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);grid-column:1/-1}.pdp-contractor-payments h3{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.pdp-contractor-payment-row{gap:var(--spacing-md);padding:var(--spacing-md) 0;border-bottom:1px solid var(--color-border);font-size:var(--font-size-sm);grid-template-columns:1fr auto auto auto;align-items:center;display:grid}.pdp-contractor-payment-row:last-child{border-bottom:none}.pdp-cp-name{font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.pdp-cp-paid{color:var(--color-success)}.pdp-cp-pending{color:var(--color-warning)}.pdp-cp-total{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.pdp-contractors-header{margin-bottom:var(--spacing-lg);justify-content:space-between;align-items:center;display:flex}.pdp-contractors-header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.pdp-contractor-row{gap:var(--spacing-lg);padding:var(--spacing-lg);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--spacing-md);transition:all var(--transition-base);grid-template-columns:auto 1fr auto auto auto;align-items:center;display:grid}.pdp-contractor-row:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-md)}.pdp-contractor-avatar{background:linear-gradient(135deg, var(--color-accent-primary), var(--color-accent-secondary));width:44px;height:44px;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:#fff;border-radius:50%;justify-content:center;align-items:center;display:flex}.pdp-contractor-info{min-width:0}.pdp-contractor-name{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-size:var(--font-size-base)}.pdp-contractor-role{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.pdp-contractor-contact{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.pdp-contractor-stars{color:var(--color-warning);font-size:var(--font-size-sm)}.pdp-contractor-contract{text-align:right}.pdp-contractor-contract-val{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.pdp-contractor-contract-lbl{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.pdp-contractor-status{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.pdp-team-header{margin-bottom:var(--spacing-lg);justify-content:space-between;align-items:center;display:flex}.pdp-team-header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.pdp-team-grid{gap:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(260px,1fr));display:grid}.pdp-team-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);gap:var(--spacing-md);transition:all var(--transition-base);align-items:flex-start;display:flex}.pdp-team-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.pdp-team-avatar{background:linear-gradient(135deg, var(--color-accent-primary), var(--color-accent-secondary));width:48px;height:48px;font-size:var(--font-size-base);font-weight:var(--font-weight-bold);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.pdp-team-info{flex:1;min-width:0}.pdp-team-name{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.pdp-team-role{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.pdp-team-email{font-size:var(--font-size-xs);color:var(--color-text-tertiary);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;overflow:hidden}.pdp-team-tasks{margin-top:var(--spacing-sm);align-items:center;gap:4px;display:flex}.pdp-team-tasks-badge{background:var(--color-accent-glow);color:var(--color-accent-primary);font-size:11px;font-weight:var(--font-weight-semibold);border-radius:99px;padding:2px 8px}.pdp-activity-header{margin-bottom:var(--spacing-xl);justify-content:space-between;align-items:center;display:flex}.pdp-activity-header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.pdp-activity-timeline{padding-left:32px;position:relative}.pdp-activity-timeline:before{content:"";background:var(--color-border);width:2px;position:absolute;top:0;bottom:0;left:11px}.pdp-activity-entry{margin-bottom:var(--spacing-xl);animation:.2s ease-out fadeIn;position:relative}.pdp-activity-dot{background:var(--color-bg-elevated);border:2px solid var(--color-border);z-index:1;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:10px;display:flex;position:absolute;top:4px;left:-26px}.pdp-activity-dot.type-create{background:var(--color-accent-glow);border-color:var(--color-accent-primary)}.pdp-activity-dot.type-task{border-color:var(--color-warning);background:#f59e0b26}.pdp-activity-dot.type-expense{border-color:var(--color-error);background:#ef44441f}.pdp-activity-dot.type-note{border-color:var(--color-success);background:#22c55e1f}.pdp-activity-dot.type-contractor{background:#a855f71f;border-color:#a855f7}.pdp-activity-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md) var(--spacing-lg)}.pdp-activity-card-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:4px}.pdp-activity-card-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary);gap:var(--spacing-md);display:flex}.pdp-add-note-form{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-xl);gap:var(--spacing-md);display:flex}.pdp-add-note-form textarea{padding:var(--spacing-md);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:inherit;font-size:var(--font-size-sm);resize:none;flex:1;height:60px}.pdp-add-note-form textarea:focus{border-color:var(--color-accent-primary);outline:none}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.85)}}.btn-danger{background:var(--color-error);color:#fff;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);cursor:pointer;align-items:center;gap:var(--spacing-xs);border:none;font-weight:500;transition:opacity .15s;display:inline-flex}.btn-danger:hover{opacity:.85}.btn-sm{font-size:var(--font-size-xs);padding:6px 12px}.avatar-xl{background:var(--color-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.25rem;font-weight:700;display:flex}.pdp-tags-wrap{gap:var(--spacing-xs);flex-wrap:wrap;display:flex}.pdp-expense-ledger{border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-top:var(--spacing-md);flex-direction:column;gap:1px;display:flex;overflow:hidden}.pdp-expense-item{padding:var(--spacing-md) var(--spacing-lg);background:var(--color-surface);justify-content:space-between;align-items:center;transition:background .15s;display:flex}.pdp-expense-item:hover{background:var(--color-hover)}.pdp-expense-item+.pdp-expense-item{border-top:1px solid var(--color-border)}.pdp-expense-info{flex:1;min-width:0}.pdp-expense-desc{color:var(--color-text-primary);font-weight:500;font-size:var(--font-size-sm);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.pdp-expense-meta{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:2px}.pdp-expense-amount{font-size:var(--font-size-md);white-space:nowrap;margin-left:var(--spacing-md);font-weight:600}.settings-page{padding:var(--spacing-xl);height:100%}.settings-layout{gap:var(--spacing-xl);grid-template-columns:220px 1fr;height:100%;display:grid}.settings-sidebar{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-lg);height:fit-content}.settings-sidebar-title{font-size:var(--font-size-lg);color:var(--color-text-primary);margin-bottom:var(--spacing-lg);font-weight:700}.settings-nav{flex-direction:column;gap:4px;display:flex}.settings-nav-item{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer;text-align:left;background:0 0;border:none;width:100%;font-weight:500;transition:all .15s;display:flex}.settings-nav-item:hover{background:var(--color-hover);color:var(--color-text-primary)}.settings-nav-item.active{background:linear-gradient(135deg, var(--color-accent-primary), var(--color-accent-secondary));color:#fff}.settings-content{min-width:0}.settings-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden}.settings-panel-header{padding:var(--spacing-xl) var(--spacing-xl) var(--spacing-lg);border-bottom:1px solid var(--color-border)}.settings-panel-header h3{font-size:var(--font-size-xl);color:var(--color-text-primary);margin-bottom:4px;font-weight:700}.settings-section{padding:var(--spacing-xl);border-bottom:1px solid var(--color-border)}.settings-section-title{font-size:var(--font-size-md);color:var(--color-text-primary);margin-bottom:var(--spacing-lg);font-weight:600}.settings-footer{padding:var(--spacing-lg) var(--spacing-xl);justify-content:flex-end;display:flex}.logo-upload-area{align-items:center;gap:var(--spacing-lg);flex-wrap:wrap;display:flex}.logo-upload-placeholder{justify-content:center;align-items:center;gap:var(--spacing-xs);border:2px dashed var(--color-border);border-radius:var(--radius-lg);width:140px;height:100px;color:var(--color-text-secondary);font-size:var(--font-size-sm);text-align:center;padding:var(--spacing-md);flex-direction:column;display:flex}.logo-preview-img{object-fit:contain;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-background);max-width:160px;max-height:80px;padding:8px}.firm-logo-brand{flex-direction:column;align-items:flex-start;gap:2px;width:100%;display:flex}.firm-logo-img{object-fit:contain;max-width:140px;max-height:42px}.powered-by{color:var(--color-text-secondary);letter-spacing:.02em;opacity:.7;font-size:10px}.pdp-cover-photo{border-radius:var(--border-radius-lg);background:linear-gradient(135deg, var(--color-bg-elevated) 0%, var(--color-bg-tertiary) 100%);cursor:pointer;width:100%;height:180px;margin-bottom:var(--spacing-lg);border:2px dashed var(--color-border);background-position:50%;background-size:cover;transition:all .3s;position:relative;overflow:hidden}.pdp-cover-photo.has-photo{border:none;height:220px}.pdp-cover-photo:hover{border-color:var(--color-accent-primary)}.pdp-cover-photo.has-photo:hover .pdp-cover-overlay{opacity:1}.pdp-cover-placeholder{justify-content:center;align-items:center;gap:var(--spacing-sm);height:100%;color:var(--color-text-tertiary);font-size:var(--font-size-sm);flex-direction:column;display:flex}.pdp-cover-placeholder svg{opacity:.4}.pdp-cover-overlay{padding:var(--spacing-md);color:#fff;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);align-items:center;gap:var(--spacing-xs);opacity:0;background:linear-gradient(#0000,#000000b3);transition:opacity .3s;display:flex;position:absolute;bottom:0;left:0;right:0}.pdp-title-input{width:100%;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);background:var(--color-bg-elevated);border:2px solid var(--color-accent-primary);border-radius:var(--border-radius-md);padding:var(--spacing-xs) var(--spacing-sm);outline:none;font-family:inherit;box-shadow:0 0 0 4px #d4af3726}.pdp-title-block h1{transition:color .2s}.pdp-title-block h1:hover{color:var(--color-accent-primary)}.pfs-container{padding:var(--spacing-md) 0}.pfs-header{margin-bottom:var(--spacing-lg);justify-content:space-between;align-items:center;display:flex}.pfs-header h3{align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0;display:flex}.pfs-empty{padding:var(--spacing-xxl) var(--spacing-lg);text-align:center;color:var(--color-text-tertiary);background:var(--color-bg-elevated);border-radius:var(--border-radius-lg);border:2px dashed var(--color-border);flex-direction:column;justify-content:center;align-items:center;display:flex}.pfs-empty svg{opacity:.3;margin-bottom:var(--spacing-md)}.pfs-empty h4{color:var(--color-text-secondary);margin:0 0 var(--spacing-xs);font-size:var(--font-size-md)}.pfs-empty p{margin:0 0 var(--spacing-lg);font-size:var(--font-size-sm)}.pfs-folders{gap:var(--spacing-md);flex-direction:column;display:flex}.pfs-folder{background:var(--color-bg-elevated);border-radius:var(--border-radius-lg);border:1px solid var(--color-border);transition:border-color .2s,box-shadow .2s;overflow:hidden}.pfs-folder:hover{border-color:var(--color-accent-primary);box-shadow:0 2px 8px #00000014}.pfs-folder-header{padding:var(--spacing-md) var(--spacing-lg);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;transition:background .2s;display:flex}.pfs-folder-header:hover{background:var(--color-bg-tertiary)}.pfs-folder-info{align-items:center;gap:var(--spacing-md);display:flex}.pfs-folder-icon{color:var(--color-accent-primary);flex-shrink:0}.pfs-folder-name{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-size:var(--font-size-md)}.pfs-folder-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:2px}.pfs-folder-actions{align-items:center;gap:var(--spacing-xs);display:flex}.pfs-chevron{color:var(--color-text-tertiary);margin-left:var(--spacing-sm);transition:transform .2s}.pfs-folder.expanded .pfs-chevron{transform:rotate(180deg)}.pfs-action-btn{border-radius:var(--border-radius-sm);width:28px;height:28px;color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:all .2s;display:flex}.pfs-action-btn:hover{background:var(--color-bg-tertiary);color:var(--color-accent-primary)}.pfs-action-btn.pfs-danger:hover{color:#ef4444;background:#ef44441a}.pfs-folder-content{border-top:1px solid var(--color-border)}.pfs-folder-empty{justify-content:center;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg);color:var(--color-text-tertiary);font-size:var(--font-size-sm);display:flex}.pfs-upload-link{color:var(--color-accent-primary);cursor:pointer;font-size:var(--font-size-sm);background:0 0;border:none;padding:0;text-decoration:underline}.pfs-file-list{padding:var(--spacing-xs) 0}.pfs-file-row{align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-lg);transition:background .15s;display:flex}.pfs-file-row:hover{background:var(--color-bg-tertiary)}.pfs-file-icon{background:var(--color-bg-tertiary);border-radius:var(--border-radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.pfs-file-info{flex:1;min-width:0}.pfs-file-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.pfs-file-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:1px}.pfs-file-actions{gap:var(--spacing-xs);opacity:0;flex-shrink:0;transition:opacity .2s;display:flex}.pfs-file-row:hover .pfs-file-actions{opacity:1}
.auth-page{background:var(--color-bg-primary);min-height:100vh;padding:var(--spacing-xl);justify-content:center;align-items:center;display:flex}.auth-container{width:100%;max-width:480px;position:relative}.auth-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-2xl);z-index:2;box-shadow:var(--shadow-xl);position:relative}.auth-header{text-align:center;margin-bottom:var(--spacing-2xl)}.auth-header .logo{align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xl);display:inline-flex}.auth-header h1{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-xs)}.auth-header p{color:var(--color-text-secondary);font-size:var(--font-size-base)}.auth-form{gap:var(--spacing-lg);flex-direction:column;display:flex}.form-row{gap:var(--spacing-md);grid-template-columns:1fr 1fr;display:grid}.form-group label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--spacing-xs);display:block}.form-group input{width:100%;padding:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:inherit;font-size:var(--font-size-base);transition:all var(--transition-base)}.form-group input:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 3px var(--color-accent-glow);outline:none}.form-group input::placeholder{color:var(--color-text-tertiary)}.form-hint{margin-top:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--color-text-tertiary);display:block}.form-options{margin-top:calc(var(--spacing-lg) * -1);justify-content:space-between;align-items:center;display:flex}.checkbox-label{align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text-secondary);display:flex}.checkbox-label input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:var(--color-accent-primary)}.link{color:var(--color-accent-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:color var(--transition-base)}.link:hover{color:var(--color-accent-secondary)}.auth-divider{text-align:center;margin:var(--spacing-xl) 0;position:relative}.auth-divider:before{content:"";background:var(--color-border);height:1px;position:absolute;top:50%;left:0;right:0}.auth-divider span{padding:0 var(--spacing-md);background:var(--color-bg-secondary);color:var(--color-text-tertiary);font-size:var(--font-size-sm);display:inline-block;position:relative}.auth-social{gap:var(--spacing-md);flex-direction:column;display:flex}.social-btn{justify-content:center;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);transition:all var(--transition-base);cursor:pointer;display:flex}.social-btn:hover{background:var(--color-bg-elevated);border-color:var(--color-border-hover)}.auth-footer{text-align:center;margin-top:var(--spacing-xl);padding-top:var(--spacing-xl);border-top:1px solid var(--color-border)}.auth-footer p{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.auth-background{z-index:0;pointer-events:none;position:fixed;inset:0}.background-pattern{background-image:radial-gradient(circle at 20%,#1e3a8a0d 0%,#0000 50%),radial-gradient(circle at 80% 80%,#f4e5b00d 0%,#0000 50%);animation:20s ease-in-out infinite backgroundShift;position:absolute;inset:0}@keyframes backgroundShift{0%,to{transform:translate(0)}50%{transform:translate(20px,20px)}}@media (max-width:768px){.auth-page{padding:var(--spacing-md)}.auth-card{padding:var(--spacing-xl)}.form-row{grid-template-columns:1fr}.form-options{align-items:flex-start;gap:var(--spacing-sm);flex-direction:column}}
.marketing-page{background:var(--color-bg-primary);position:relative;overflow-x:hidden}.navbar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border);z-index:1000;padding:var(--spacing-md) 0;background:#f9fafbd9;transition:all .3s;position:fixed;top:0;left:0;right:0}.navbar.scrolled{background:#f9fafbf2;box-shadow:0 4px 20px #0000000f}.container{max-width:1200px;padding:0 var(--spacing-xl);margin:0 auto}.nav-content{justify-content:space-between;align-items:center;display:flex}.nav-logo{align-items:center;gap:var(--spacing-sm);text-decoration:none;display:flex}.nav-logo-text{font-size:var(--font-size-lg);color:var(--color-text-primary);letter-spacing:-.02em;font-weight:800}.nav-links{align-items:center;gap:var(--spacing-xl);display:flex}.nav-links a{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);transition:color var(--transition-base);text-decoration:none}.nav-links a:hover{color:var(--color-text-primary)}.nav-auth{align-items:center;gap:var(--spacing-sm);display:flex}.btn-client-login{opacity:.6;cursor:not-allowed;position:relative}.coming-soon-badge{color:#fff;text-transform:uppercase;letter-spacing:.05em;background:linear-gradient(135deg,#ef4444,#f97316);border-radius:9999px;padding:2px 6px;font-size:9px;font-weight:700;animation:2s ease-in-out infinite badgePulse;position:absolute;top:-8px;right:-8px}@keyframes badgePulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.hero{padding:160px 0 100px;position:relative;overflow:hidden}.hero-grid{gap:var(--spacing-2xl);grid-template-columns:1fr .9fr;align-items:center;display:grid}.hero-title{margin-bottom:var(--spacing-lg);color:var(--color-text-primary);letter-spacing:-.03em;font-size:clamp(36px,4.5vw,56px);font-weight:800;line-height:1.1}.gradient-text{background:linear-gradient(135deg, var(--color-accent-primary), var(--color-accent-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-subtitle{font-size:var(--font-size-lg);color:var(--color-text-secondary);margin-bottom:var(--spacing-2xl);max-width:520px;line-height:1.7}.hero-cta{gap:var(--spacing-md);margin-bottom:var(--spacing-lg);flex-wrap:wrap;display:flex}.btn-large{padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-base)}.hero-note{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.btn-outline{border:1px solid var(--color-border);color:var(--color-text-primary);background:0 0}.btn-outline:hover{background:var(--color-surface);border-color:var(--color-border-hover)}.hero-visual{position:relative}.hero-mockup{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:0 25px 50px -12px #00000014, 0 0 0 1px var(--color-border);transition:transform .6s;overflow:hidden;transform:perspective(1200px)rotateY(-8deg)rotateX(4deg)}.hero-mockup:hover{transform:perspective(1200px)rotateY(-2deg)rotateX(1deg)}.mockup-bar{border-bottom:1px solid var(--color-border);gap:6px;padding:10px 14px;display:flex}.mockup-bar span{background:var(--color-border);border-radius:50%;width:10px;height:10px}.mockup-content{padding:var(--spacing-md);gap:var(--spacing-md);min-height:200px;display:flex}.mockup-sidebar-mini{flex-direction:column;gap:8px;width:48px;display:flex}.mockup-sidebar-item{background:var(--color-border);border-radius:4px;height:8px}.mockup-sidebar-item.active{background:var(--color-accent-primary)}.mockup-main{flex-direction:column;flex:1;gap:8px;display:flex}.mockup-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;height:50px;animation:2s ease-in-out infinite pulse}.mockup-card.sm{height:30px}.mockup-card:nth-child(2){animation-delay:.3s}.mockup-card:nth-child(3){animation-delay:.6s}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.trust-bar{padding:var(--spacing-2xl) 0;background:var(--color-bg-secondary);border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.trust-stats{justify-content:center;align-items:center;gap:var(--spacing-2xl);flex-wrap:wrap;display:flex}.trust-stat{text-align:center}.trust-number{color:var(--color-accent-primary);font-size:clamp(28px,3vw,40px);font-weight:800;display:inline}.trust-plus{color:var(--color-accent-primary);font-size:clamp(20px,2vw,28px);font-weight:700}.trust-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--spacing-xs);display:block}.trust-divider{background:var(--color-border);width:1px;height:40px}.section-header-center{text-align:center;max-width:700px;margin:0 auto var(--spacing-2xl);opacity:0;transition:all .6s;transform:translateY(20px)}.section-header-center.revealed{opacity:1;transform:translateY(0)}.section-label{padding:var(--spacing-xs) var(--spacing-md);background:var(--color-accent-glow);color:var(--color-accent-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-md);border-radius:9999px;display:inline-block}.section-title{margin-bottom:var(--spacing-md);color:var(--color-text-primary);font-size:clamp(28px,3.5vw,44px);font-weight:800}.section-description{font-size:var(--font-size-lg);color:var(--color-text-secondary);line-height:1.6}.features{padding:100px 0}.features-grid{gap:var(--spacing-lg);grid-template-columns:repeat(3,1fr);display:grid}.feature-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);opacity:0;transition:all .35s;transform:translateY(20px)}.feature-card.revealed{opacity:1;transform:translateY(0)}.feature-card:hover{border-color:var(--color-border-hover);box-shadow:0 20px 40px -15px #1e3a8a14, 0 0 0 1px var(--color-border);transform:translateY(-4px)}.feature-card-icon{background:linear-gradient(135deg, var(--color-accent-glow), #3b82f60f);width:48px;height:48px;color:var(--color-accent-primary);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);justify-content:center;align-items:center;transition:all .3s;display:flex}.feature-card:hover .feature-card-icon{background:linear-gradient(135deg, var(--color-accent-primary), var(--color-accent-secondary));color:#fff;transform:scale(1.05)}.feature-card h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-sm);color:var(--color-text-primary)}.feature-card p{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.65}.ai-hero-card{margin-bottom:var(--spacing-2xl);padding:var(--spacing-2xl);border-radius:var(--radius-xl);color:#fff;opacity:0;background:linear-gradient(135deg,#0f172a,#1e3a8a);transition:all .6s;position:relative;overflow:hidden;transform:translateY(24px)}.ai-hero-card.revealed{opacity:1;transform:translateY(0)}.ai-hero-glow{pointer-events:none;background:radial-gradient(circle,#3b82f640 0%,#0000 60%);width:500px;height:500px;animation:6s ease-in-out infinite aiGlow;position:absolute;top:-50%;right:-20%}@keyframes aiGlow{0%,to{opacity:.6;transform:translate(0)scale(1)}50%{opacity:1;transform:translate(-30px,20px)scale(1.1)}}.ai-hero-content{z-index:2;gap:var(--spacing-2xl);grid-template-columns:1.2fr .8fr;align-items:center;display:grid;position:relative}.ai-hero-badge{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-md);color:#93c5fd;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-md);background:#3b82f633;border:1px solid #3b82f64d;border-radius:9999px;width:fit-content;display:inline-flex}.ai-hero-title{margin-bottom:var(--spacing-md);background:linear-gradient(135deg,#fff,#93c5fd);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:clamp(24px,3vw,36px);font-weight:800;line-height:1.15}.ai-hero-subtitle{font-size:var(--font-size-base);color:#ffffffbf;margin-bottom:var(--spacing-lg);line-height:1.7}.ai-hero-capabilities{gap:var(--spacing-md);flex-direction:column;padding:0;list-style:none;display:flex}.ai-hero-capabilities li{align-items:flex-start;gap:var(--spacing-sm);font-size:var(--font-size-sm);color:#ffffffd9;line-height:1.6;display:flex}.ai-hero-capabilities li svg{color:#fbbf24;flex-shrink:0;margin-top:3px}.ai-hero-capabilities li strong{color:#fff}.ai-chat-mockup{border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff0f;border:1px solid #ffffff1a;overflow:hidden}.ai-chat-header{align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:#fff;background:#ffffff0d;border-bottom:1px solid #ffffff14;padding:12px 16px;display:flex}.ai-chat-avatar{color:#fff;background:linear-gradient(135deg,#3b82f6,#1e3a8a);border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.ai-chat-online{font-size:11px;font-weight:var(--font-weight-medium);color:#4ade80;align-items:center;gap:4px;margin-left:auto;display:flex}.ai-chat-online:before{content:"";background:#4ade80;border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite onlinePulse}@keyframes onlinePulse{0%,to{opacity:1}50%{opacity:.4}}.ai-chat-messages{flex-direction:column;gap:12px;padding:16px;display:flex}.ai-msg{border-radius:12px;max-width:92%;padding:10px 14px;font-size:13px;line-height:1.5}.ai-msg.user{color:#dbeafe;background:#3b82f64d;border:1px solid #3b82f633;border-bottom-right-radius:4px;align-self:flex-end}.ai-msg.bot{color:#ffffffe6;background:#ffffff14;border:1px solid #ffffff0f;border-bottom-left-radius:4px;align-self:flex-start}.ai-typing{gap:4px;margin-bottom:6px;display:flex}.ai-typing span{background:#93c5fd;border-radius:50%;width:6px;height:6px;animation:1.4s ease-in-out infinite both typingDot}.ai-typing span:first-child{animation-delay:-.32s}.ai-typing span:nth-child(2){animation-delay:-.16s}.ai-typing span:nth-child(3){animation-delay:0s}@keyframes typingDot{0%,80%,to{opacity:.4;transform:scale(.5)}40%{opacity:1;transform:scale(1)}}.feature-card-whatsapp{background:linear-gradient(135deg, var(--color-surface), #25d36608);border-color:#25d36633}.feature-card-whatsapp:hover{border-color:#25d36666;box-shadow:0 20px 40px -15px #25d3661f,0 0 0 1px #25d36614}.feature-card-whatsapp .feature-card-icon{color:#25d366;background:linear-gradient(135deg,#25d3661a,#25d3660d)}.feature-card-whatsapp:hover .feature-card-icon{color:#fff;background:linear-gradient(135deg,#25d366,#128c7e)}.faq-section{background:var(--color-bg-secondary);padding:100px 0}.faq-list{gap:var(--spacing-sm);flex-direction:column;max-width:760px;margin:0 auto;display:flex}.faq-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);opacity:0;transition:all .4s;overflow:hidden;transform:translateY(16px)}.faq-item.revealed{opacity:1;transform:translateY(0)}.faq-question{width:100%;padding:var(--spacing-lg) var(--spacing-xl);cursor:pointer;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;font-family:inherit;transition:background .2s;display:flex}.faq-question:hover{background:var(--color-bg-secondary)}.faq-chevron{color:var(--color-text-tertiary);flex-shrink:0;transition:transform .3s}.faq-item.open .faq-chevron{color:var(--color-accent-primary);transform:rotate(180deg)}.faq-answer{max-height:0;padding:0 var(--spacing-xl);transition:max-height .35s,padding .35s;overflow:hidden}.faq-item.open .faq-answer{max-height:300px;padding:0 var(--spacing-xl) var(--spacing-lg)}.faq-answer p{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.7}.cta-section{background:linear-gradient(135deg,#1e3a8a0f,#3b82f608);padding:100px 0}.cta-content-center{text-align:center;max-width:600px;margin:0 auto}.cta-content-center h2{margin-bottom:var(--spacing-md);color:var(--color-text-primary);font-size:clamp(28px,3.5vw,44px);font-weight:800}.cta-content-center p{font-size:var(--font-size-lg);color:var(--color-text-secondary);margin-bottom:var(--spacing-2xl)}.footer{padding:var(--spacing-2xl) 0;background:var(--color-bg-secondary);border-top:1px solid var(--color-border)}.footer-content{margin-bottom:var(--spacing-2xl);justify-content:space-between;display:flex}.footer-brand{max-width:300px}.footer-brand p{margin-top:var(--spacing-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.6}.footer-links{gap:var(--spacing-2xl);display:flex}.footer-column h4{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-md);color:var(--color-text-primary)}.footer-column a{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-sm);transition:color var(--transition-base);text-decoration:none;display:block}.footer-column a:hover{color:var(--color-accent-primary)}.footer-bottom{padding-top:var(--spacing-xl);border-top:1px solid var(--color-border);text-align:center}.footer-bottom p{color:var(--color-text-tertiary);font-size:var(--font-size-sm)}@media (max-width:1024px){.hero-grid{grid-template-columns:1fr}.hero-visual{display:none}.hero-subtitle{max-width:100%}.features-grid{grid-template-columns:repeat(2,1fr)}.ai-hero-content{grid-template-columns:1fr}.ai-hero-right{display:none}}@media (max-width:768px){.hero{padding:120px 0 60px}.hero-title{font-size:32px}.section-title{font-size:28px}.hero-cta{flex-direction:column}.features-grid{grid-template-columns:1fr}.trust-stats{gap:var(--spacing-lg);flex-direction:column}.trust-divider{width:40px;height:1px}.nav-links{display:none}.nav-auth{gap:var(--spacing-xs)}.btn-client-login{display:none}.footer-content{gap:var(--spacing-xl);flex-direction:column}.footer-links{gap:var(--spacing-lg);flex-direction:column}.ai-hero-card{padding:var(--spacing-xl)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
