*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary: #0F172A;--color-primary-foreground: #F8FAFC;--color-accent: #0EAFC7;--color-accent-foreground: #FFFFFF;--color-surface: #FFFFFF;--color-surface-alt: #F1F5F9;--color-border: #E2E8F0;--color-text-primary: #0F172A;--color-text-secondary: #64748B;--color-success: #10B981;--color-warning: #F59E0B;--color-danger: #EF4444;--color-sidebar: #0F172A;--color-sidebar-foreground: #F8FAFC;--font-heading: "DM Sans", sans-serif;--font-body: "DM Sans", sans-serif;--font-mono: "Space Mono", monospace;--transition-ease: cubic-bezier(.16, 1, .3, 1);--sidebar-width: 260px;--header-height: 64px;--text-page-title: 24px;--weight-page-title: 600;--tracking-page-title: -.02em;--text-section-heading: 18px;--weight-section-heading: 600;--tracking-section-heading: -.01em;--text-card-title: 16px;--weight-card-title: 600;--text-body: 14px;--weight-body: 400;--leading-body: 1.5;--text-secondary: 13px;--weight-secondary: 400;--text-label: 12px;--weight-label: 500;--tracking-label: .02em;--text-caption: 12px;--weight-caption: 400;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 28px;--space-8: 32px;--space-9: 36px;--space-10: 40px;--space-11: 44px;--space-12: 48px;--color-accent-soft: rgba(14, 175, 199, .1);--color-success-soft: rgba(16, 185, 129, .1);--color-warning-soft: rgba(245, 158, 11, .1);--color-danger-soft: rgba(239, 68, 68, .1);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-pill: 100px}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);color:var(--color-text-primary);background:var(--color-surface);line-height:1.5}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600;line-height:1.2}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}a{color:var(--color-accent);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;display:block}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:10px;font-family:var(--font-body);font-size:.938rem;font-weight:500;cursor:pointer;border:none;transition:all .2s var(--transition-ease);line-height:1.4}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--color-accent);color:var(--color-accent-foreground)}.btn-primary:hover:not(:disabled){filter:brightness(.9);transform:translateY(-1px);box-shadow:0 4px 12px #0eafc74d}.btn-outline{background:transparent;color:var(--color-accent);border:1.5px solid var(--color-accent)}.btn-outline:hover:not(:disabled){background:var(--color-accent);color:var(--color-accent-foreground)}.btn-ghost{background:transparent;color:var(--color-text-secondary);padding:8px}.btn-ghost:hover{background:var(--color-surface-alt);color:var(--color-text-primary)}.btn-danger{color:var(--color-danger)}.btn-danger:hover{background:var(--color-danger-soft);color:var(--color-danger)}.btn-full{width:100%}.input{width:100%;padding:10px 14px;border:1.5px solid var(--color-border);border-radius:10px;font-family:var(--font-body);font-size:.938rem;color:var(--color-text-primary);background:var(--color-surface);transition:border-color .2s var(--transition-ease),box-shadow .2s var(--transition-ease);outline:none}.input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #0eafc726}.input::placeholder{color:var(--color-text-secondary)}.input-group{display:flex;flex-direction:column;gap:6px}.input-group label{font-size:.875rem;font-weight:500;color:var(--color-text-primary)}.auth-layout{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}.auth-brand{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--color-primary);color:var(--color-primary-foreground);padding:40px;position:relative;overflow:hidden}.auth-brand-logo{width:120px;margin-bottom:24px;position:relative;z-index:1}.auth-brand-title{font-size:2rem;font-weight:700;color:var(--color-accent);margin-bottom:8px;position:relative;z-index:1}.auth-brand-tagline{font-size:1.125rem;opacity:.8;position:relative;z-index:1}.auth-brand-circle{position:absolute;width:400px;height:400px;border-radius:50%;background:var(--color-accent);opacity:.06;bottom:-100px;right:-100px}.auth-form-panel{display:flex;align-items:center;justify-content:center;padding:40px}.auth-form{width:100%;max-width:400px}.auth-form h1{margin-bottom:8px}.auth-form-subtitle{color:var(--color-text-secondary);margin-bottom:32px}.auth-form .input-group{margin-bottom:20px}.auth-form .btn{margin-top:8px}.auth-form-footer{text-align:center;margin-top:24px;font-size:.875rem;color:var(--color-text-secondary)}.auth-form-footer a{font-weight:500}.auth-form-link{display:block;text-align:right;font-size:.875rem;margin-bottom:8px}.auth-error{background:#ef444414;color:var(--color-danger);padding:10px 14px;border-radius:8px;font-size:.875rem;margin-bottom:16px}.auth-success{background:#10b98114;color:var(--color-success);padding:10px 14px;border-radius:8px;font-size:.875rem;margin-bottom:16px}.auth-readonly-email{padding:10px 14px;background:var(--color-surface-alt);border-radius:10px;font-size:.938rem;color:var(--color-text-secondary);margin-bottom:20px}@media (max-width: 768px){.auth-layout{grid-template-columns:1fr}.auth-brand{display:none}}.dashboard-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--color-sidebar);color:var(--color-sidebar-foreground);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:50;transition:transform .3s var(--transition-ease)}.sidebar-header{display:flex;align-items:center;gap:12px;padding:20px 20px 16px}.sidebar-logo{width:48px}.sidebar-title{font-size:1.25rem;font-weight:700;color:var(--color-accent)}.sidebar-close{display:none;margin-left:auto;background:none;border:none;color:var(--color-sidebar-foreground);cursor:pointer;padding:4px;opacity:.7}.sidebar-close:hover{opacity:1}.sidebar-nav{flex:1;padding:8px 12px;overflow-y:auto}.sidebar-divider{height:1px;background:#ffffff1a;margin:12px 8px}.sidebar-link{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;color:var(--color-sidebar-foreground);opacity:.7;font-size:.938rem;font-weight:500;text-decoration:none;transition:all .15s var(--transition-ease)}.sidebar-link:hover{opacity:1;background:#ffffff14;text-decoration:none}.sidebar-link.active{opacity:1;background:var(--color-accent);color:var(--color-accent-foreground)}.sidebar-link svg{width:20px;height:20px;flex-shrink:0}.sidebar-user{padding:16px 20px;border-top:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:12px}.sidebar-avatar{width:36px;height:36px;border-radius:50%;background:var(--color-accent);color:var(--color-accent-foreground);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0}.sidebar-user-name{font-size:.875rem;font-weight:500}.sidebar-user-role{font-size:.75rem;opacity:.6;text-transform:capitalize}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:40}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-close,.sidebar-backdrop.visible{display:block}}.header{height:var(--header-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;padding:0 24px;gap:16px;position:fixed;top:0;right:0;left:var(--sidebar-width);z-index:30}.header-menu-btn{display:none;background:none;border:none;color:var(--color-text-primary);cursor:pointer;padding:4px}.header-search{flex:1;max-width:400px}.header-search .input{background:var(--color-surface-alt);border-color:transparent}.header-search .input:focus{background:var(--color-surface);border-color:var(--color-accent)}.header-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.header-notification{position:relative;background:none;border:none;color:var(--color-text-secondary);cursor:pointer;padding:8px;border-radius:8px;transition:background .15s}.header-notification:hover{background:var(--color-surface-alt);color:var(--color-text-primary)}.header-notification-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--color-danger)}.header-user-btn{display:flex;align-items:center;gap:8px;background:none;border:none;cursor:pointer;padding:4px;border-radius:8px;transition:background .15s}.header-user-btn:hover{background:var(--color-surface-alt)}.header-avatar{width:32px;height:32px;border-radius:50%;background:var(--color-accent);color:var(--color-accent-foreground);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.813rem}.header-dropdown{position:absolute;top:calc(var(--header-height) - 4px);right:24px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;box-shadow:0 8px 24px #0000001f;min-width:180px;padding:6px;z-index:100;animation:dropdown-in .15s var(--transition-ease)}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.header-dropdown-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:6px;font-size:.875rem;color:var(--color-text-primary);cursor:pointer;background:none;border:none;width:100%;text-align:left;font-family:var(--font-body);text-decoration:none;transition:background .1s}.header-dropdown-item:hover{background:var(--color-surface-alt);text-decoration:none}.header-dropdown-item.danger{color:var(--color-danger)}@media (max-width: 768px){.header{left:0}.header-menu-btn{display:block}}.dashboard-content{margin-left:var(--sidebar-width);margin-top:var(--header-height);padding:32px;background:var(--color-surface-alt);min-height:calc(100vh - var(--header-height))}.dashboard-content-inner{max-width:1100px}@media (max-width: 768px){.dashboard-content{margin-left:0}}.module-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px;margin-top:24px}.module-card{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:14px;padding:24px;text-decoration:none;color:var(--color-text-primary);transition:all .2s var(--transition-ease);display:flex;flex-direction:column;gap:14px;position:relative;overflow:hidden}.module-card:hover{border-color:var(--color-accent);box-shadow:0 4px 16px #0eafc71a;transform:translateY(-2px);text-decoration:none}.module-card:hover .module-card-arrow{transform:translate(4px);opacity:1}.module-card-icon{width:44px;height:44px;border-radius:10px;background:#0eafc71a;color:var(--color-accent);display:flex;align-items:center;justify-content:center}.module-card-icon svg{width:22px;height:22px}.module-card-title{font-size:1rem;font-weight:600}.module-card-desc{font-size:.875rem;color:var(--color-text-secondary);line-height:1.5}.module-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto}.module-card-badge{font-size:.75rem;font-weight:500;padding:4px 10px;border-radius:100px;background:var(--color-surface-alt);color:var(--color-text-secondary)}.module-card-arrow{color:var(--color-accent);opacity:0;transition:all .2s var(--transition-ease)}.spinner-container{display:flex;align-items:center;justify-content:center;min-height:100vh}.spinner{width:36px;height:36px;border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes skeleton-pulse{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.skeleton{background:linear-gradient(90deg,var(--color-surface-alt) 0%,var(--color-border) 50%,var(--color-surface-alt) 100%);background-size:200px 100%;animation:skeleton-pulse 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}.skeleton-text{height:14px;width:100%;margin-bottom:8px}.skeleton-group .skeleton-text:last-child{width:60%}.skeleton-heading{height:24px;width:40%;margin-bottom:16px}.skeleton-card{height:120px;border-radius:var(--radius-lg)}.skeleton-circle{border-radius:50%}.skeleton-badge{height:24px;width:80px;border-radius:var(--radius-pill)}.toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column-reverse;gap:8px;z-index:1000;pointer-events:none}.toast{pointer-events:auto;background:var(--color-surface);border:1px solid var(--color-border);border-left:4px solid;border-radius:var(--radius-md);padding:12px 16px;box-shadow:0 8px 24px #0000001f;display:flex;align-items:flex-start;gap:12px;min-width:320px;max-width:420px;animation:toast-in .2s var(--transition-ease)}.toast-error{border-left-color:var(--color-danger)}.toast-success{border-left-color:var(--color-success)}.toast-warning{border-left-color:var(--color-warning)}.toast-info{border-left-color:var(--color-accent)}.toast-icon{flex-shrink:0;width:20px;height:20px}.toast-error .toast-icon{color:var(--color-danger)}.toast-success .toast-icon{color:var(--color-success)}.toast-warning .toast-icon{color:var(--color-warning)}.toast-info .toast-icon{color:var(--color-accent)}.toast-content{flex:1;font-size:var(--text-body)}.toast-title{font-weight:600;font-size:var(--text-body);margin-bottom:2px}.toast-message{color:var(--color-text-secondary);font-size:var(--text-secondary)}.toast-close{flex-shrink:0;background:none;border:none;color:var(--color-text-secondary);cursor:pointer;padding:4px;border-radius:var(--radius-sm);transition:background .15s}.toast-close:hover{background:var(--color-surface-alt)}@keyframes toast-in{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.toast-exit{animation:toast-out .15s var(--transition-ease) forwards}@keyframes toast-out{to{opacity:0;transform:translate(16px)}}@media (max-width: 768px){.toast-container{left:16px;right:16px;bottom:16px}.toast{min-width:0;max-width:none}}.status-badge{display:inline-flex;align-items:center;height:24px;padding:4px 10px;font-size:12px;font-weight:500;border-radius:var(--radius-pill);white-space:nowrap;line-height:1}.status-badge-draft,.status-badge-not-started{color:var(--color-text-secondary);background:var(--color-surface-alt)}.status-badge-in-progress,.status-badge-open{color:var(--color-accent);background:var(--color-accent-soft)}.status-badge-in-review,.status-badge-pending{color:var(--color-warning);background:var(--color-warning-soft)}.status-badge-revision,.status-badge-overdue{color:var(--color-danger);background:var(--color-danger-soft)}.status-badge-approved,.status-badge-paid,.status-badge-completed{color:var(--color-success);background:var(--color-success-soft)}.status-badge-sent{color:var(--color-accent);background:var(--color-accent-soft)}.status-badge-void{color:var(--color-text-secondary);background:var(--color-surface-alt)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;display:flex;align-items:center;justify-content:center;animation:fade-in .15s var(--transition-ease)}.modal{background:var(--color-surface);border-radius:var(--radius-lg);width:90%;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:modal-in .15s var(--transition-ease)}.modal:focus{outline:none}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-6);border-bottom:1px solid var(--color-border)}.modal-title{font-size:var(--text-section-heading);font-weight:var(--weight-section-heading);letter-spacing:var(--tracking-section-heading)}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text-secondary);transition:background .15s var(--transition-ease)}.modal-close:hover{background:var(--color-surface-alt)}.modal-body{padding:var(--space-6)}@keyframes modal-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@media (max-width: 768px){.modal{width:100%;max-height:100vh;border-radius:0}}.page-title{font-size:var(--text-page-title);font-weight:var(--weight-page-title);letter-spacing:var(--tracking-page-title)}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-5)}.project-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-6);border:1px solid var(--color-border);text-decoration:none;color:inherit;display:block;transition:all .2s var(--transition-ease)}.project-card:hover{border-color:var(--color-accent);box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.project-card-title{font-size:var(--text-card-title);font-weight:var(--weight-card-title);margin-bottom:var(--space-2)}.project-card-desc{font-size:var(--text-secondary);color:var(--color-text-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:var(--space-4)}.project-card-meta{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-caption);color:var(--color-text-secondary);margin-bottom:var(--space-3)}.project-card-progress{height:4px;background:var(--color-surface-alt);border-radius:var(--radius-pill);overflow:hidden;margin-bottom:var(--space-3)}.project-card-progress-fill{height:100%;background:var(--color-accent);border-radius:var(--radius-pill);transition:width .3s var(--transition-ease)}.project-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:var(--space-2)}.project-card-clients{display:flex;align-items:center}.project-card-avatar{width:24px;height:24px;border-radius:50%;background:var(--color-accent);color:var(--color-accent-foreground);display:inline-flex;align-items:center;justify-content:center;font-size:var(--text-caption);font-weight:600;border:2px solid var(--color-surface);margin-left:-4px}.project-card-avatar-sm{width:28px;height:28px}.project-card-avatar:first-child{margin-left:0}.project-card-overflow{font-size:var(--text-caption);color:var(--color-text-secondary);margin-left:var(--space-2)}.project-card-visibility{color:var(--color-text-secondary)}.project-card-visibility.visible{color:var(--color-accent)}.project-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6)}.project-back-link{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-body);color:var(--color-text-secondary);text-decoration:none;margin-bottom:var(--space-4);transition:color .2s var(--transition-ease)}.project-back-link:hover{color:var(--color-accent)}.project-controls{display:flex;gap:var(--space-4);align-items:center}.visibility-toggle{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:none;background:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text-secondary);font-size:var(--text-secondary);transition:all .15s var(--transition-ease)}.visibility-toggle:hover{background:var(--color-surface-alt)}.visibility-toggle.visible{color:var(--color-accent)}.project-progress-summary{margin-bottom:var(--space-6)}.project-progress-bar{height:6px;background:var(--color-surface-alt);border-radius:var(--radius-pill);overflow:hidden;margin-bottom:var(--space-2)}.project-progress-bar-fill{height:100%;background:var(--color-accent);border-radius:var(--radius-pill);transition:width .3s var(--transition-ease)}.project-progress-text{font-size:var(--text-caption);color:var(--color-text-secondary)}.milestone-section{margin-bottom:var(--space-6)}.milestone-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);background:var(--color-surface-alt);border-radius:var(--radius-md);margin-bottom:var(--space-2)}.milestone-title{font-size:var(--text-section-heading);font-weight:var(--weight-section-heading);letter-spacing:var(--tracking-section-heading)}.milestone-progress-text{font-size:var(--text-caption);color:var(--color-text-secondary)}.milestone-progress-bar{height:3px;background:var(--color-surface-alt);border-radius:var(--radius-pill);overflow:hidden;margin-bottom:var(--space-2)}.milestone-progress-bar-fill{height:100%;background:var(--color-accent);border-radius:var(--radius-pill);transition:width .3s var(--transition-ease)}.deliverable-row{display:flex;align-items:center;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);gap:var(--space-3);min-height:48px;transition:background .15s var(--transition-ease)}.deliverable-row:hover{background:var(--color-surface-alt)}.deliverable-row:last-child{border-bottom:none}.deliverable-name{flex:1;font-size:var(--text-body);font-weight:var(--weight-body)}.deliverable-checkbox{width:18px;height:18px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;accent-color:var(--color-accent)}.deliverable-status-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;border:none;cursor:pointer;font-family:var(--font-body);height:28px;padding:var(--space-1) var(--space-6) var(--space-1) var(--space-3);border-radius:var(--radius-pill);font-size:var(--text-caption);font-weight:var(--weight-label);background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='currentColor' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.deliverable-status-select:focus-visible{outline:2px solid var(--color-accent);outline-offset:1px}.status-select-not-started{background:var(--color-surface-alt);color:var(--color-text-secondary)}.status-select-in-progress{background:var(--color-accent-soft);color:var(--color-accent)}.status-select-in-review{background:var(--color-warning-soft);color:var(--color-warning)}.status-select-approved{background:var(--color-success-soft);color:var(--color-success)}.bulk-action-bar{position:sticky;bottom:0;display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-6);background:var(--color-surface);border-top:1px solid var(--color-border);box-shadow:0 -4px 12px #0000000d;z-index:10}.template-preview{background:var(--color-surface-alt);padding:var(--space-4);border-radius:var(--radius-md);margin-top:var(--space-4)}.template-preview-milestone{font-size:var(--text-label);font-weight:var(--weight-label);letter-spacing:var(--tracking-label);margin-top:var(--space-3);text-transform:uppercase}.template-preview-deliverable{font-size:var(--text-caption);color:var(--color-text-secondary);padding-left:var(--space-6);padding-top:var(--space-1)}.client-select-list{display:flex;flex-direction:column;gap:var(--space-2);max-height:200px;overflow-y:auto}.client-select-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2);border-radius:var(--radius-md);cursor:pointer;transition:background .15s var(--transition-ease)}.client-select-item:hover{background:var(--color-surface-alt)}.form-group{margin-bottom:var(--space-4)}.form-label{display:block;font-size:var(--text-label);font-weight:var(--weight-label);letter-spacing:var(--tracking-label);color:var(--color-text-secondary);margin-bottom:var(--space-2);text-transform:uppercase}.form-input{width:100%;padding:var(--space-2) var(--space-3);font-family:var(--font-body);font-size:var(--text-body);color:var(--color-text-primary);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color .15s var(--transition-ease)}.form-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 2px var(--color-accent-soft)}.form-input:disabled{opacity:.6;cursor:not-allowed}textarea.form-input{resize:vertical;min-height:80px}select.form-input{cursor:pointer}.form-row{display:flex;gap:var(--space-4)}.form-row .form-group{flex:1}.form-error{display:block;font-size:var(--text-caption);color:var(--color-danger);margin-top:var(--space-1)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-6)}@media (max-width: 768px){.project-grid{grid-template-columns:1fr}.project-header{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.deliverable-row{flex-wrap:wrap;min-height:var(--space-11)}.deliverable-name{width:100%}.bulk-action-bar{padding:var(--space-3) var(--space-4)}.deliverable-status-select{min-height:var(--space-11)}.form-row{flex-direction:column;gap:0}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center}.empty-state-icon{color:var(--color-text-secondary);margin-bottom:16px}.empty-state-title{font-size:var(--text-section-heading);font-weight:600;margin-bottom:8px}.empty-state-text{font-size:var(--text-body);color:var(--color-text-secondary);max-width:360px;margin-bottom:20px}.text-secondary{color:var(--color-text-secondary)}.text-danger{color:var(--color-danger)}.text-success{color:var(--color-success)}.error-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;text-align:center;padding:40px}.error-screen h1{margin-bottom:8px}.error-screen p{color:var(--color-text-secondary)}.dashboard-greeting{margin-bottom:8px}.dashboard-greeting h1{font-size:1.75rem}.dashboard-greeting p{color:var(--color-text-secondary)}.client-group-header{font-size:var(--text-secondary);font-weight:var(--weight-secondary);color:var(--color-text-secondary);margin-bottom:var(--space-2)}.client-group-list{display:flex;flex-direction:column;gap:var(--space-2)}.client-group-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.client-group-item.inactive{opacity:.6}.client-group-item-info{display:flex;align-items:center;gap:var(--space-3)}.client-group-item-name{font-size:var(--text-card-title);font-weight:var(--weight-card-title);color:var(--color-text-primary)}.client-group-item-actions{display:flex;gap:var(--space-2)}.project-card-group-name{font-size:var(--text-caption);font-weight:var(--weight-caption);color:var(--color-text-secondary)}.comment-thread{margin-top:var(--space-8);padding-top:var(--space-6);border-top:1px solid var(--color-border)}.comment-thread-title{font-size:var(--text-section-heading);font-weight:var(--weight-section-heading);letter-spacing:var(--tracking-section-heading);color:var(--color-text-primary);display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-4)}.comment-form{margin-bottom:var(--space-6)}.comment-form textarea{min-height:80px;width:100%;resize:vertical}.comment-form-footer{display:flex;align-items:center;justify-content:space-between;margin-top:var(--space-3);gap:var(--space-3)}.comment-internal-toggle{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-secondary);color:var(--color-text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.comment-internal-toggle input[type=checkbox]{width:16px;height:16px;cursor:pointer}.comment-empty{font-size:var(--text-secondary);color:var(--color-text-secondary);padding:var(--space-4) 0}.comment-list{display:flex;flex-direction:column;gap:var(--space-3)}.comment-item{padding:var(--space-4);background:var(--color-surface-alt);border-radius:var(--radius-md);border-left:3px solid transparent}.comment-item.internal{border-left-color:var(--color-warning)}.comment-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2);flex-wrap:wrap;gap:var(--space-2)}.comment-author{display:flex;align-items:center;gap:var(--space-2)}.comment-author-name{font-size:var(--text-body);font-weight:600;color:var(--color-text-primary)}.comment-role-badge{font-size:var(--text-caption);font-weight:var(--weight-caption);color:var(--color-text-secondary);text-transform:capitalize}.comment-internal-badge{font-size:var(--text-label);font-weight:var(--weight-label);letter-spacing:var(--tracking-label);background:var(--color-warning-soft);color:var(--color-warning);padding:2px var(--space-2);border-radius:var(--radius-sm);text-transform:uppercase}.comment-timestamp{font-size:var(--text-caption);font-weight:var(--weight-caption);color:var(--color-text-secondary)}.comment-content{font-size:var(--text-body);font-weight:var(--weight-body);line-height:var(--leading-body);color:var(--color-text-primary);white-space:pre-wrap}@media (max-width: 768px){.comment-header{flex-direction:column;align-items:flex-start}.comment-form-footer{flex-direction:column;align-items:stretch}.comment-form-footer .btn{width:100%}.client-group-item{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.client-group-item-actions{width:100%}.client-group-item-actions .btn{min-height:44px}}.template-editor{max-width:720px;margin:0 auto}.template-editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6)}.template-editor-actions{display:flex;gap:var(--space-3)}.milestone-card{border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--space-4);overflow:hidden}.milestone-card-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);background:var(--color-surface-alt);cursor:pointer}.milestone-card-header:hover{background:var(--color-surface-hover)}.milestone-card-body{padding:var(--space-4);border-top:1px solid var(--color-border)}.milestone-name-input{flex:1;font-weight:600;border:none;background:transparent;font-size:var(--text-card-title);color:var(--color-text-primary);outline:none;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}.milestone-name-input:focus{background:var(--color-surface);box-shadow:0 0 0 2px var(--color-accent)}.milestone-name-input.input-error{box-shadow:0 0 0 2px var(--color-danger)}.milestone-actions{display:flex;gap:var(--space-2);align-items:center}.deliverable-row-editor{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-border)}.deliverable-row-editor:last-of-type{border-bottom:none}.deliverable-name-input{flex:1;border:none;background:transparent;font-size:var(--text-body);color:var(--color-text-primary);outline:none;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}.deliverable-name-input:focus{background:var(--color-surface-alt);box-shadow:0 0 0 2px var(--color-accent)}.deliverable-name-input.input-error{box-shadow:0 0 0 2px var(--color-danger)}.reorder-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition-default)}.reorder-btn:hover{background:var(--color-surface-alt)}.reorder-btn:disabled{opacity:.3;cursor:not-allowed}.reorder-btn.danger:hover{background:#ef44441a;color:var(--color-danger)}.add-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:1px dashed var(--color-border);border-radius:var(--radius-md);background:transparent;color:var(--color-text-secondary);cursor:pointer;width:100%;font-size:var(--text-body);transition:var(--transition-default);margin-top:var(--space-3)}.add-btn:hover{border-color:var(--color-accent);color:var(--color-accent);background:#0eafc70d}.add-btn:disabled{opacity:.5;cursor:not-allowed}.template-list{display:flex;flex-direction:column;gap:var(--space-3)}.template-list-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);transition:var(--transition-default)}.template-list-item:hover{border-color:var(--color-accent);box-shadow:var(--shadow-sm)}.template-list-item-info{display:flex;flex-direction:column;gap:var(--space-1)}.template-list-item-name{font-weight:600;font-size:var(--text-card-title);color:var(--color-text-primary)}.template-list-item-link{background:none;border:none;padding:0;cursor:pointer;text-align:left}.template-list-item-link:hover{color:var(--color-accent)}.template-list-item-description{font-size:var(--text-body);color:var(--color-text-secondary)}.template-list-item-meta{font-size:var(--text-caption);color:var(--color-text-secondary);display:flex;gap:var(--space-4)}.template-list-item-actions{display:flex;gap:var(--space-2)}.icon-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition-default)}.icon-btn:hover{background:var(--color-surface-alt);color:var(--color-text-primary)}.icon-btn.danger:hover{background:#ef44441a;color:var(--color-danger)}@media (max-width: 768px){.template-editor-header{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.template-editor-actions{width:100%}.template-editor-actions .btn{flex:1}.template-list-item{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.template-list-item-actions{width:100%;justify-content:flex-end}.deliverable-row-editor{flex-wrap:wrap}.deliverable-name-input{min-width:0}}.billing-summary{display:flex;gap:var(--space-4);margin-bottom:var(--space-6)}.billing-summary-card{flex:1;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-2)}.billing-summary-card-overdue{border-color:var(--color-danger)}.billing-summary-label{font-size:var(--text-label);font-weight:var(--weight-label);letter-spacing:var(--tracking-label);color:var(--color-text-secondary);text-transform:uppercase}.billing-summary-amount{font-size:var(--text-page-title);font-weight:var(--weight-page-title);letter-spacing:var(--tracking-page-title);color:var(--color-text-primary)}.billing-filters{display:flex;gap:var(--space-3);margin-bottom:var(--space-6);flex-wrap:wrap}.billing-filters .form-input{width:auto;min-width:160px}.invoice-table{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.invoice-table-header{display:grid;grid-template-columns:1.2fr 1fr 1.5fr 1fr 1fr .8fr .8fr;padding:var(--space-3) var(--space-4);background:var(--color-surface-alt);font-size:var(--text-label);font-weight:var(--weight-label);letter-spacing:var(--tracking-label);color:var(--color-text-secondary);text-transform:uppercase;border-bottom:1px solid var(--color-border)}.invoice-row{display:grid;grid-template-columns:1.2fr 1fr 1.5fr 1fr 1fr .8fr .8fr;padding:var(--space-3) var(--space-4);align-items:center;font-size:var(--text-body);cursor:pointer;transition:background .2s var(--transition-ease);border-bottom:1px solid var(--color-border)}.invoice-row:last-child{border-bottom:none}.invoice-row:hover{background:var(--color-surface-alt)}.invoice-row-number{font-family:var(--font-mono);font-size:var(--text-caption)}.invoice-row-desc{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.invoice-row-amount{font-weight:600}.invoice-row-actions{display:flex;gap:var(--space-1);justify-content:flex-end}.text-right{text-align:right}.invoice-detail-section{margin-top:var(--space-6);margin-bottom:var(--space-6)}.invoice-detail-row{display:flex;gap:var(--space-4);padding:var(--space-3) 0;border-bottom:1px solid var(--color-border);font-size:var(--text-body)}.invoice-detail-label{min-width:140px;color:var(--color-text-secondary);font-weight:var(--weight-label);font-size:var(--text-secondary)}.invoice-line-items{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.invoice-line-items-header{display:grid;grid-template-columns:2fr .5fr 1fr 1fr;padding:var(--space-3) var(--space-4);background:var(--color-surface-alt);font-size:var(--text-label);font-weight:var(--weight-label);letter-spacing:var(--tracking-label);color:var(--color-text-secondary);text-transform:uppercase;border-bottom:1px solid var(--color-border)}.invoice-line-items-row{display:grid;grid-template-columns:2fr .5fr 1fr 1fr;padding:var(--space-3) var(--space-4);font-size:var(--text-body);border-bottom:1px solid var(--color-border)}.invoice-line-items-row:last-child{border-bottom:none}.invoice-line-items-footer{display:grid;grid-template-columns:3.5fr 1fr;padding:var(--space-3) var(--space-4);font-size:var(--text-body);background:var(--color-surface-alt);border-top:1px solid var(--color-border)}.line-item-editor{margin-bottom:var(--space-2)}.line-item-editor-fields{display:flex;gap:var(--space-2);align-items:center}.line-item-desc{flex:2}.line-item-amount{flex:1;max-width:140px}.line-item-qty{flex:0 0 70px;max-width:70px}.line-item-total{display:flex;justify-content:space-between;padding:var(--space-4) 0;margin-top:var(--space-4);border-top:2px solid var(--color-border);font-size:var(--text-card-title);font-weight:var(--weight-card-title)}.pay-now-btn{display:inline-flex;align-items:center;gap:var(--space-2);width:100%;justify-content:center;padding:var(--space-4);font-size:var(--text-card-title);font-weight:var(--weight-card-title);margin-top:var(--space-4);margin-bottom:var(--space-4);text-decoration:none}@media (max-width: 768px){.billing-summary,.billing-filters{flex-direction:column}.billing-filters .form-input{width:100%;min-width:0}.invoice-table-header{display:none}.invoice-row{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4)}.invoice-row-actions{width:100%;justify-content:flex-start}.invoice-line-items-header{display:none}.invoice-line-items-row{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-3) var(--space-4)}.invoice-line-items-footer{display:flex;justify-content:space-between}.line-item-editor-fields{flex-wrap:wrap}.line-item-desc{flex:1 1 100%}.line-item-amount,.line-item-qty{flex:1;max-width:none}.invoice-detail-row{flex-direction:column;gap:var(--space-1)}.invoice-detail-label{min-width:0}.pay-now-btn{width:100%}}
