:root{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.4;color:#101828}*{box-sizing:border-box}body{margin:0;background:#f6f7fb}.page{padding:24px}.shell{max-width:1100px;margin:0 auto}.hero{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:16px}.cards{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));display:grid;gap:12px}.card{background:#fff;border-radius:8px;padding:12px;border:1px solid #e3e8ef}.metric{display:flex;align-items:center;justify-content:flex-start;gap:12px}.metric-label{margin:0}.metric-value{font-size:28px}.panel{margin-top:16px;background:#fff;border-radius:8px;border:1px solid #e3e8ef;padding:16px}.inline-form,.stack-form{display:grid;gap:12px}label{display:grid;gap:6px;font-size:14px;font-weight:500}input,select,textarea,button{padding:10px;border:1px solid #d7deea;border-radius:6px;font:inherit}button{width:max-content;cursor:pointer;background:#1d4ed8;color:#fff;border-color:#1d4ed8}button:disabled{opacity:.55;cursor:default}.project-grid,.review-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.user-list{display:grid;gap:10px}.user-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border:1px solid #e3e8ef;border-radius:8px}.user-main{display:flex;align-items:center;gap:10px;min-width:0}.user-main img{width:34px;height:34px;border-radius:50%}.user-main span{display:block;color:#667085;overflow-wrap:anywhere}.user-role-control{display:flex;align-items:center;gap:8px}.role-pill{border:1px solid #bfd0ff;background:#eef4ff;color:#1d4ed8;border-radius:999px;padding:4px 8px;font-size:12px;font-weight:700;white-space:nowrap}.actions{display:flex;gap:12px;flex-wrap:wrap}.error{color:#b42318}.success{color:#18794e}.image-panel{position:relative;overflow:hidden;border-radius:8px;border:1px solid #d4deef}.review-image{width:100%;display:block}.pin{position:absolute;transform:translate(-50%,-50%);width:24px;height:24px;border-radius:999px;display:grid;place-items:center;color:#fff;font-size:12px;font-weight:700;background:#4338ca}.pin.open{background:#0ea5e9}.pin.in-progress{background:#f59e0b}.pin.resolved{background:#16a34a}.pin.active-draft{background:#ef4444}.filter-row,.comment-actions{display:flex;gap:12px;flex-wrap:wrap}.comment-card{margin-top:8px;border:1px solid #d4deef;border-radius:8px;padding:12px}.comment-header{display:flex;gap:10px;align-items:center}.muted{color:#667085}.back-link{text-decoration:none}.hint{margin-top:8px;color:#667085}.auth-bar{display:flex;align-items:center;gap:10px}.auth-user{display:flex;align-items:center;gap:8px;color:#344054;font-size:14px}.auth-user img{width:28px;height:28px;border-radius:999px}.attachment-list{display:grid;gap:6px}.attachment-list a{color:#1d4ed8;text-decoration:none}.attachment-list a:hover{text-decoration:underline}.review-workspace{min-height:100vh;display:grid;grid-template-rows:52px 1fr;background:#eef1f6}.review-toolbar{height:52px;display:grid;grid-template-columns:minmax(220px,1fr) auto minmax(220px,1fr);align-items:center;gap:16px;padding:0 12px;background:#fff;border-bottom:1px solid #d9dee8;position:sticky;top:0;z-index:20}.review-meta,.toolbar-actions,.mode-switch,.rail-tabs,.comment-meta-row,.composer-actions,.composer-title,.file-picker,.search-box,.add-note-button{display:flex;align-items:center}.review-meta{min-width:0;gap:10px}.review-meta strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.asset-chip{padding:3px 8px;border-radius:999px;background:#f1f5f9;color:#475467;font-size:11px;text-transform:uppercase;letter-spacing:.04em}.mode-switch{justify-self:center;border:1px solid #cbd5e1;border-radius:6px;overflow:hidden;background:#f8fafc}.mode-switch button,.rail-tabs button,.icon-button,.share-button,.add-note-button,.ghost-button{width:auto;border-radius:0}.mode-switch button{display:inline-flex;align-items:center;gap:6px;padding:9px 14px;color:#1f2937;background:transparent;border:0}.mode-switch button.is-active{color:#fff;background:#4f5cff}.toolbar-actions{justify-content:flex-end;gap:8px}.icon-button,.share-button{min-height:34px;display:inline-flex;align-items:center;gap:6px;padding:8px 10px;border:1px solid #d7deea;border-radius:6px;color:#101828;background:#fff;text-decoration:none}.status-pill{min-height:34px;display:inline-grid;place-items:center;padding:7px 12px;border-radius:6px;background:#2639d8;color:#fff;font-size:14px;font-weight:700}.review-shell{min-height:0;display:grid;grid-template-columns:minmax(0,1fr) 380px}.review-canvas{min-width:0;min-height:0;display:grid;grid-template-rows:minmax(0,1fr) 42px;border-right:1px solid #d9dee8}.canvas-scroll{min-height:0;overflow:auto;padding:18px}.review-board{width:min(100%,1160px);margin:0 auto;overflow:visible;background:#fff;cursor:default}.review-board.can-comment{cursor:crosshair}.review-board img{width:100%;display:block;-webkit-user-select:none;user-select:none}.canvas-footer{display:flex;align-items:center;justify-content:center;gap:18px;color:#475467;background:#f8fafc;border-top:1px solid #d9dee8;font-size:13px}.pin{padding:0;border:2px solid #fff;box-shadow:0 8px 24px #4f5cff4d;z-index:3}.pin.selected{outline:4px solid rgb(79 92 255 / 24%)}.pin-preview{position:absolute;left:50%;bottom:calc(100% + 10px);width:220px;display:none;transform:translate(-50%);padding:10px;border:1px solid #d7deea;border-radius:8px;background:#fff;color:#101828;box-shadow:0 16px 40px #0f172a2e;text-align:left;pointer-events:none}.pin-preview span{display:block;margin-top:3px;color:#475467;font-size:12px;font-weight:500}.pin:hover .pin-preview,.pin:focus-visible .pin-preview{display:block}.pin.active-draft{background:#4f5cff}.draft-pin-wrap{position:absolute;transform:translate(-50%,-50%);z-index:8}.draft-pin-wrap>.pin{position:static;transform:none}.draft-composer{position:absolute;left:30px;top:18px;width:min(360px,calc(100vw - 48px));display:grid;gap:10px;padding:14px;border-radius:8px;border:1px solid #d7deea;background:#fff;box-shadow:0 24px 60px #0f172a38;cursor:auto}.composer-title{gap:8px;color:#344054;font-weight:700}.composer-row{display:grid;grid-template-columns:1fr;gap:10px}.file-picker{grid-auto-flow:column;justify-content:flex-start;gap:8px;width:max-content;padding:8px 10px;border:1px dashed #b9c4d5;border-radius:6px;color:#344054;cursor:pointer}.file-picker input{position:absolute;inline-size:1px;block-size:1px;opacity:0}.composer-actions{justify-content:flex-end;gap:8px}.ghost-button{color:#344054;background:#fff;border-color:#d7deea}.comments-rail{min-height:0;display:grid;grid-template-rows:auto auto auto auto minmax(0,1fr);gap:10px;padding:16px;background:#fff}.rail-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.rail-header h2,.rail-header p{margin:0}.rail-header p{color:#667085;font-size:13px}.rail-tabs{gap:6px}.rail-tabs button{flex:1;justify-content:center;padding:9px 10px;color:#344054;background:#f8fafc;border-color:#e3e8ef;border-radius:6px}.rail-tabs button.is-active{background:#101828;color:#fff;border-color:#101828}.search-box{grid-template-columns:auto 1fr;gap:8px;padding:0 10px;border:1px solid #d7deea;border-radius:6px;color:#667085;font-weight:400}.search-box input{border:0;padding:9px 0;outline:none}.add-note-button{justify-content:center;gap:8px;width:100%;padding:10px;border-radius:6px;border:1px dashed #cbd5e1;color:#101828;background:#fff}.rail-comments{min-height:0;overflow:auto;margin:0 -16px;border-top:1px solid #edf1f7}.rail-comment{display:grid;grid-template-columns:28px minmax(0,1fr);gap:10px;padding:16px;border-bottom:1px solid #edf1f7;cursor:pointer}.rail-comment.selected{background:#f6f8ff}.comment-avatar{width:28px;height:28px;display:grid;place-items:center;border-radius:999px;background:#dbeafe;color:#1e40af;font-size:11px;font-weight:800;overflow:hidden}.comment-avatar img{width:100%;height:100%;object-fit:cover}.comment-body{min-width:0}.comment-title-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.comment-title-actions{display:inline-flex;align-items:center;gap:6px}.comment-body p{margin:3px 0 8px}.comment-pin{min-width:24px;height:24px;display:inline-grid;place-items:center;border-radius:999px;color:#fff;background:#4f5cff;font-size:12px;font-weight:800;border:0;padding:0}.comment-pin.resolved{background:#16a34a}.comment-pin.in-progress{background:#f59e0b}.comment-meta-row{gap:8px;flex-wrap:wrap;color:#667085;font-size:13px}.task-actions{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-top:10px}.task-actions label{width:min(170px,100%)}.task-actions select{width:100%;padding:8px;border:1px solid #d7deea;border-radius:6px;background:#fff}.task-actions button,.inline-actions button{justify-content:center;gap:6px;min-height:34px;padding:7px 9px}.icon-button.compact-icon,.compact-icon{width:28px;height:28px;min-height:28px;padding:0}.danger-button{color:#b42318;border-color:#fecaca}.inline-editor{display:grid;gap:8px;margin:8px 0}.inline-editor textarea{min-height:88px;width:100%;resize:vertical;padding:9px;border:1px solid #d7deea;border-radius:6px}.inline-actions{display:flex;gap:8px}.attachment-list.compact a{display:inline-flex;align-items:center;gap:6px;width:max-content;padding:6px 8px;border:1px solid #e3e8ef;border-radius:6px;color:#344054}.attachment-thumb{display:inline-grid;grid-template-columns:44px minmax(0,1fr) auto;align-items:center;gap:8px;width:min(100%,260px);padding:5px 8px 5px 5px;border:1px solid #e3e8ef;border-radius:6px;color:#344054;background:#fff;text-align:left}.attachment-thumb img{width:44px;height:34px;object-fit:cover;border-radius:4px;background:#f1f5f9}.attachment-thumb span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reply-list{display:grid;gap:10px;margin-top:12px;padding-left:10px;border-left:2px solid #e3e8ef}.reply-item{display:grid;grid-template-columns:24px minmax(0,1fr);gap:8px}.reply-avatar{width:24px;height:24px;font-size:10px}.reply-composer{display:grid;gap:8px;margin-top:12px;padding:10px;border:1px solid #e3e8ef;border-radius:8px;background:#f8fafc}.reply-composer textarea{width:100%;min-height:72px;resize:vertical}.reply-actions{display:flex;align-items:center;gap:8px}.compact-picker{width:34px;height:34px;padding:0;display:grid;place-items:center}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;display:grid;place-items:center;padding:24px;background:#0f172ad1}.lightbox img{max-width:min(1100px,96vw);max-height:88vh;border-radius:8px;box-shadow:0 24px 80px #00000059}.lightbox-close{position:fixed;top:18px;right:18px;width:38px;height:38px;display:grid;place-items:center;padding:0;border-radius:999px;background:#fff;color:#101828;border-color:#fff}@media(max-width:720px){.page{padding:12px}.hero{flex-direction:column}.review-toolbar{grid-template-columns:1fr;height:auto;padding:10px}.mode-switch,.toolbar-actions{justify-self:stretch}.mode-switch button,.toolbar-actions>*{flex:1;justify-content:center}.review-shell{grid-template-columns:1fr}.comments-rail{min-height:420px}.draft-composer{position:fixed;left:12px;right:12px;bottom:12px;top:auto;width:auto}}
