:root{--bg: #F8F6F3;--surface: #FFFFFF;--surface-subtle: #FAF9F7;--sidebar: #1C2B4A;--sidebar-muted: #4A6080;--sidebar-active: rgba(255,255,255,.06);--sidebar-accent: #7BA7D4;--text: #1C1917;--text-muted: #78716C;--text-faint: #B8B2AA;--accent: #2B5797;--urgent: #C53030;--warning: #B45309;--success: #2D6A4F;--border: #E5E1DB;--border-strong: #C8C2BA;--border-focus: #2B5797;--r-sm: 2px;--r-md: 4px;--r-lg: 6px;--r-xl: 8px;--ease: cubic-bezier(.4, 0, .2, 1);--ease-out: cubic-bezier(0, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:DM Sans,system-ui,sans-serif;font-size:13px;line-height:1.5;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none}input,textarea,select{font-family:inherit;font-size:13px}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:500;border-radius:var(--r-md);transition:background .15s var(--ease);white-space:nowrap}.btn-primary{background:#1c2b4a;color:#fff}.btn-primary:hover{background:#253a5f}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text-muted)}.btn-ghost:hover{background:var(--surface-subtle)}.btn-danger{background:var(--urgent);color:#fff}.btn-danger:hover{background:#b02020}.btn-sm{padding:5px 10px;font-size:12px}.input{width:100%;padding:7px 10px;border:1px solid var(--border);border-radius:var(--r-md);font-size:13px;color:var(--text);background:var(--surface);outline:none;transition:border-color .15s var(--ease)}.input:focus{border-color:var(--border-focus)}.input::placeholder{color:var(--text-faint)}.badge{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;font-size:11px;font-weight:500;border-radius:var(--r-sm);white-space:nowrap}.badge-red{background:#fef2f2;color:var(--urgent)}.badge-amber{background:#fffbeb;color:var(--warning)}.badge-green{background:#f0fdf4;color:var(--success)}.badge-grey{background:#f5f4f2;color:var(--text-faint)}.app-shell{display:flex;height:100%}.sidebar{width:196px;flex-shrink:0;background:var(--sidebar);display:flex;flex-direction:column;height:100%;position:fixed;left:0;top:0}.sidebar-logo{padding:20px 18px 16px;border-bottom:1px solid rgba(255,255,255,.07)}.sidebar-logo-text{font-size:14px;font-weight:600;color:#fff;letter-spacing:.3px}.sidebar-logo-dot{color:var(--sidebar-accent)}.sidebar-nav{flex:1;padding:8px 0}.sidebar-item{display:flex;align-items:center;gap:9px;padding:9px 18px;font-size:13px;color:#fff9;text-decoration:none;transition:color .15s var(--ease),background .15s var(--ease);border-left:2px solid transparent}.sidebar-item:hover{color:#ffffffd9;background:#ffffff0a}.sidebar-item.active{color:#fff;background:var(--sidebar-active);border-left-color:var(--sidebar-accent)}.sidebar-footer{padding:14px 18px;border-top:1px solid rgba(255,255,255,.07);font-size:11px;color:var(--sidebar-muted)}.main-content{margin-left:196px;flex:1;min-height:100%;background:var(--bg)}.page{padding:32px 32px 48px;max-width:1280px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.page-title{font-size:14px;font-weight:600;color:var(--text)}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}table{width:100%;border-collapse:collapse}thead th{background:var(--surface-subtle);padding:10px 14px;text-align:left;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);border-bottom:1px solid var(--border)}tbody td{padding:11px 14px;border-bottom:1px solid #F5F2EE;font-size:13px}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:#fafaf8}.cell-client{font-family:"Instrument Serif",Georgia,serif;font-size:13px}.cell-muted{color:var(--text-muted)}.cell-date{font-variant-numeric:tabular-nums;color:var(--text-muted);font-size:12px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg)}.card-body{padding:16px 18px}.empty-state{padding:56px 24px;text-align:center}.empty-state-title{font-size:14px;font-weight:500;margin-bottom:6px;color:var(--text)}.empty-state-sub{font-size:12px;color:var(--text-muted)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--surface);border-radius:var(--r-xl);box-shadow:0 4px 24px #0000001f;width:480px;max-width:95vw;max-height:90vh;overflow-y:auto}.modal-header{padding:18px 20px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:14px;font-weight:600}.modal-body{padding:18px 20px}.modal-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}.form-group{margin-bottom:14px}.form-label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);margin-bottom:5px}.phase-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);margin-bottom:12px}.phase-header{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border-strong);background:#ede8df;border-radius:var(--r-lg) var(--r-lg) 0 0}.phase-name{font-size:13px;font-weight:600;flex:1}.drag-handle{color:var(--text-faint);cursor:grab;padding:2px 4px;font-size:16px;line-height:1;-webkit-user-select:none;user-select:none}.drag-handle:active{cursor:grabbing}.task-row{display:flex;align-items:center;gap:10px;padding:10px 16px;border-bottom:1px solid #F5F2EE}.task-row:last-child{border-bottom:none}.task-name{flex:1;font-size:13px}.task-deadline{font-size:12px;font-variant-numeric:tabular-nums;color:var(--text-muted)}.add-row{display:flex;align-items:center;padding:8px 16px;gap:6px;color:var(--text-faint);font-size:12px;cursor:pointer;transition:color .15s var(--ease);background:none;border:none;width:100%}.add-row:hover{color:var(--accent)}.inline-input{background:transparent;border:none;border-bottom:1px solid var(--border-focus);border-radius:0;padding:2px 4px;font-size:inherit;font-family:inherit;color:var(--text);outline:none;width:100%}.upload-zone{border:1px dashed var(--border-strong);border-radius:var(--r-md);padding:20px 16px;text-align:center;cursor:pointer;transition:border-color .15s var(--ease),background .15s var(--ease)}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--accent);background:#f4f6fb}.upload-zone-text{font-size:12px;color:var(--text-muted)}.spinner{display:inline-block;width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-page{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted)}.client-page{min-height:100vh;background:var(--bg)}.client-header{background:var(--sidebar);padding:16px 24px;display:flex;align-items:center;gap:12px}.client-header-logo{font-size:14px;font-weight:600;color:#fff}.client-header-firm{font-size:12px;color:#ffffff80;margin-left:auto}.client-body{max-width:560px;margin:0 auto;padding:40px 24px}.client-greeting{font-family:"Instrument Serif",Georgia,serif;font-size:18px;margin-bottom:8px}.client-subtitle{font-size:13px;color:var(--text-muted);margin-bottom:24px}.deadline-alert{border-left:3px solid var(--urgent);background:#fef2f2;padding:10px 14px;border-radius:0 var(--r-md) var(--r-md) 0;margin-bottom:24px;font-size:12px;color:var(--urgent)}.client-footer{text-align:center;margin-top:40px;font-size:10px;color:var(--text-faint)}.doc-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);margin-bottom:12px;overflow:hidden}.doc-card-header{padding:12px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border)}.doc-card-name{font-size:13px;font-weight:500;flex:1}.doc-card-body{padding:14px 16px}.doc-card-desc{font-size:12px;color:var(--text-muted);margin-bottom:12px}.doc-received{display:flex;align-items:center;gap:8px;padding:10px 0;font-size:12px;color:var(--success)}
