*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f0f2f5;color:#1a1a2e;height:100vh;overflow:hidden}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:270px;min-width:270px;background:#1e2533;color:#c8cdd8;display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:20px 18px 14px;border-bottom:1px solid #2d3447}.sidebar-header h1{font-size:16px;font-weight:600;color:#fff;letter-spacing:.3px}.main{flex:1;overflow-y:auto;padding:0}.client-list{display:flex;flex-direction:column;overflow:hidden;flex:1}.search-wrap{padding:12px 12px 8px}.search-input{width:100%;background:#2d3447;border:1px solid #3a4460;border-radius:6px;color:#e0e4ef;font-size:13px;padding:7px 10px;outline:none}.search-input::placeholder{color:#5a6480}.search-input:focus{border-color:#4f6ef7}.alpha-buckets,.alpha-letters{display:flex;gap:4px;padding:0 12px 6px}.alpha-letters{padding-bottom:8px}.alpha-pill{flex:1;background:#2d3447;border:1px solid #3a4460;border-radius:5px;color:#a0aac0;font-size:11px;font-weight:500;padding:5px 0;cursor:pointer;transition:background .1s,color .1s,border-color .1s}.alpha-pill:hover:not(.disabled):not(:disabled){background:#3a4460;color:#e0e4ef}.alpha-pill.active{background:#4f6ef7;border-color:#4f6ef7;color:#fff}.alpha-pill.disabled,.alpha-pill:disabled{background:transparent;border-color:#2a3142;color:#3d4660;cursor:default}.client-items{overflow-y:auto;flex:1;padding:4px 0}.client-item{width:100%;background:none;border:none;cursor:pointer;text-align:left;padding:11px 16px;display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:10px;color:#a0aac0;transition:background .1s}.client-item:hover{background:#252e42;color:#e0e4ef}.client-item.active{background:#2d3a5a;color:#fff}.client-item.all-done .client-name:after{content:" ✓";color:#4caf50;font-size:11px}.client-name{font-size:16px;font-weight:500;letter-spacing:-.2px}.client-meta{display:flex;align-items:center;font-size:12px;color:#5a6480;flex-shrink:0}.client-item.active .client-meta{color:#89b}.client-progress.complete{color:#4caf50}.client-progress.partial{color:#ff9800}.no-results{padding:16px;font-size:12px;color:#5a6480;font-style:italic}.grid-container{padding:24px 28px}.grid-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:16px}.view-toggle{display:inline-flex;background:#e8ecf5;border-radius:8px;padding:3px;flex-shrink:0}.view-toggle-btn{background:none;border:none;padding:6px 14px;font-size:13px;font-weight:600;color:#7a8499;cursor:pointer;border-radius:6px;font-family:inherit;transition:color .12s,background .12s,box-shadow .12s}.view-toggle-btn:hover{color:#2a3050}.view-toggle-btn.active{background:#fff;color:#1a1a2e;box-shadow:0 1px 3px #1a1a2e14,0 0 0 1px #1a1a2e0a}.compact-grid{align-items:flex-end}.doc-with-year,.doc-wrap{display:flex;flex-direction:column;width:170px}.year-label-inline{font-size:17px;font-weight:600;color:#4a5470;letter-spacing:.3px;margin-bottom:12px;padding-left:2px}.client-name-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.client-name-display{font-size:22px;font-weight:600;color:#1a1a2e;letter-spacing:-.2px;line-height:1.2;cursor:pointer;padding:2px 4px;margin:-2px -4px;border-radius:6px;transition:background .15s,color .15s;position:relative}.client-name-display:after{content:"";position:absolute;left:4px;right:4px;bottom:0;height:2px;background:#4f6ef7;border-radius:2px;transform:scaleX(0);transform-origin:left center;transition:transform .25s cubic-bezier(.4,0,.2,1)}.client-header:hover .client-name-display:after,.client-name-display:focus-visible:after{transform:scaleX(1)}.client-header:hover .client-name-display{color:#2a3050}.grid-count{font-size:14px;font-weight:500;color:#9aa0b0;letter-spacing:.1px}.client-edit-pencil{display:inline-flex;align-items:center;gap:6px;background:#4f6ef7;border:none;color:#fff;font-size:12px;font-weight:600;letter-spacing:.3px;text-transform:uppercase;cursor:pointer;padding:6px 12px 6px 10px;border-radius:999px;line-height:1;opacity:0;transform:translate(-6px);pointer-events:none;transition:opacity .18s ease,transform .22s cubic-bezier(.4,0,.2,1),background .15s,box-shadow .15s;box-shadow:0 2px 6px #4f6ef740;font-family:inherit}.client-edit-pencil svg{flex-shrink:0}.client-header:hover .client-edit-pencil,.client-edit-pencil:focus-visible{opacity:1;transform:translate(0);pointer-events:auto}.client-edit-pencil:hover{background:#3a5ce0;box-shadow:0 3px 10px #4f6ef766}.client-edit-pencil:active{transform:translate(0) translateY(1px);box-shadow:0 1px 3px #4f6ef74d}.client-edit{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.client-edit-input{font-size:18px;font-weight:600;color:#1a1a2e;letter-spacing:-.2px;border:1px solid #d8dce8;border-radius:6px;padding:5px 10px;outline:none;width:180px;font-family:inherit;background:#fff;transition:border-color .15s,box-shadow .15s}.client-edit-input:focus{border-color:#4f6ef7;box-shadow:0 0 0 3px #4f6ef726}.client-edit-btn{padding:9px 16px;border-radius:8px;border:1px solid #d8dce8;background:#fff;color:#4a5470;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .12s,border-color .12s,transform .08s}.client-edit-btn:hover{background:#f5f7fa;border-color:#c0c5d4}.client-edit-btn:active{transform:translateY(1px)}.client-edit-btn.save{background:#4f6ef7;border-color:#4f6ef7;color:#fff;box-shadow:0 2px 6px #4f6ef740}.client-edit-btn.save:hover{background:#3a5ce0;border-color:#3a5ce0}.grid-badge{font-size:13px;font-weight:500;padding:5px 12px;border-radius:20px;white-space:nowrap}.badge-complete{background:#e8f5e9;color:#2e7d32}.badge-partial{background:#fff3e0;color:#e65100}.badge-none{background:#f5f5f5;color:#9e9e9e}.thumb-grid{display:flex;flex-wrap:wrap;gap:16px}.year-group{margin-bottom:28px}.year-group:last-child{margin-bottom:0}.year-heading{font-size:17px;font-weight:600;color:#4a5470;letter-spacing:.3px;margin-bottom:12px;padding-bottom:6px;border-bottom:1px solid #e0e4ef}.doc-card{width:170px;background:#fff;border-radius:8px;box-shadow:0 1px 4px #0000001a;overflow:hidden;transition:box-shadow .15s,transform .15s;position:relative}.doc-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.doc-card.doc-processed{outline:2px solid #4caf50;outline-offset:-1px}.doc-thumb{width:170px;height:220px;overflow:hidden;cursor:pointer;position:relative;background:#f5f7fa}.doc-thumb img{width:100%;height:100%;object-fit:cover;object-position:top;display:block}.doc-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:12px;background:linear-gradient(135deg,#f0f4ff,#e8edf8)}.placeholder-form{font-size:13px;font-weight:600;color:#5a6ea0;text-align:center;line-height:1.4}.doc-thumb-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#1e25338c;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;color:#fff;font-size:13px;font-weight:600;letter-spacing:.3px}.doc-thumb:hover .doc-thumb-overlay{opacity:1}.doc-info{padding:8px 10px;display:flex;flex-direction:column;gap:6px}.doc-title{display:flex;flex-direction:column;gap:1px}.doc-year{font-size:11px;color:#9aa0b0;font-weight:500}.doc-form{font-size:12px;font-weight:600;color:#2a3050;line-height:1.3}.processed-btn{font-size:11px;font-weight:500;padding:3px 8px;border-radius:4px;border:1px solid #d0d5e0;background:#f5f7fa;color:#7a8499;cursor:pointer;transition:all .1s;align-self:flex-start}.processed-btn:hover{background:#e8ecf5}.processed-btn.is-processed{background:#e8f5e9;border-color:#a5d6a7;color:#2e7d32}.doc-has-notes{position:absolute;top:6px;right:6px;font-size:14px;background:#ffffffe6;border-radius:4px;padding:1px 3px;pointer-events:none}.viewer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;z-index:100;display:flex;align-items:center;justify-content:center;padding:8px}.viewer-modal{background:#fff;border-radius:8px;width:100%;max-width:none;height:100%;max-height:none;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #0006}.viewer-header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border-bottom:1px solid #e8ecf5;background:#f8f9fc;flex-shrink:0}.viewer-title{display:flex;align-items:center;gap:10px}.viewer-year{font-size:13px;background:#e8ecf8;color:#4f6ef7;font-weight:700;padding:2px 8px;border-radius:4px}.viewer-form{font-size:16px;font-weight:600;color:#1a1a2e}.viewer-client{font-size:13px;color:#7a8499}.viewer-close{background:none;border:none;font-size:18px;color:#9aa0b0;cursor:pointer;padding:4px 8px;border-radius:4px;line-height:1}.viewer-close:hover{background:#f0f2f5;color:#1a1a2e}.viewer-body{display:flex;flex:1;overflow:hidden}.viewer-pdf{flex:1;background:#525659;overflow:hidden}.viewer-pdf iframe{width:100%;height:100%;border:none;display:block}.loading,.error,.empty-state{display:flex;align-items:center;justify-content:center;height:100%;font-size:15px;color:#7a8499;padding:40px;text-align:center;flex-direction:column;gap:10px}.error{color:#c0392b}.error code{background:#f5f5f5;padding:2px 6px;border-radius:4px;font-size:12px}
