:root{--bg:#fbfbf9;--surface:hsla(0,0%,100%,.88);--surface-2:rgba(0,0,0,.03);--surface-3:rgba(0,0,0,.06);--border:rgba(0,0,0,.09);--border-med:rgba(0,0,0,.14);--text:#1a1a1a;--text-muted:#6b6b6b;--text-faint:#9a9a9a;--accent:#a78bfa;--accent-dim:rgba(167,139,250,.12);--danger:#ef4444;--success:#10b981;--font-sans:"Inter",-apple-system,sans-serif;--font-serif:"Playfair Display",Georgia,serif;--font-mono:"JetBrains Mono",monospace;--radius-pill:100px;--radius-card:12px;--ease:cubic-bezier(.16,1,.3,1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}.page-signin{align-items:center;justify-content:center;min-height:100vh;padding:24px}.page-app,.page-signin{display:flex;flex-direction:column}.page-app{height:100vh;overflow:hidden}.signin-card{width:100%;max-width:380px;background:#fff;border:1px solid var(--border);border-radius:16px;padding:40px 36px;box-shadow:0 4px 32px rgba(0,0,0,.07)}.signin-brand{text-align:center;margin-bottom:28px}.brand-title{font-family:var(--font-serif);font-style:italic;font-size:38px;font-weight:600;color:var(--text);line-height:1;margin-bottom:9px}.brand-sub{font-family:var(--font-mono);font-size:9px;color:var(--text-faint);letter-spacing:.14em;text-transform:uppercase}.signin-divider{height:1px;background:var(--border);margin-bottom:26px}.signin-form .field-group{margin-bottom:14px}.form-label{font-family:var(--font-mono);font-size:9px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);margin-bottom:6px;display:block}.signin-input{background:var(--bg);border:1px solid var(--border-med);border-radius:8px;color:var(--text);font-family:var(--font-sans);font-size:14px;padding:10px 13px;outline:none;width:100%;transition:border-color .18s var(--ease),box-shadow .18s var(--ease)}.signin-input:focus{border-color:var(--text);box-shadow:0 0 0 3px rgba(0,0,0,.06)}.signin-input::placeholder{color:var(--text-faint)}.signin-submit{width:100%;background:var(--text);color:#fff;border:1px solid var(--text);border-radius:100px;font-family:var(--font-sans);font-size:14px;font-weight:500;padding:12px;cursor:pointer;margin-top:6px;transition:all .2s var(--ease)}.signin-submit:hover:not(:disabled){background:#333;border-color:#333;transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,.13)}.signin-submit:disabled{opacity:.5;cursor:not-allowed}.error-msg{font-size:12px;color:var(--danger);text-align:center;margin-top:12px;line-height:1.5}.footer-note{margin-top:20px;font-family:var(--font-mono);font-size:9px;color:var(--text-faint);letter-spacing:.08em;text-align:center}.topbar{height:52px;background:var(--surface);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:14px;flex-shrink:0;z-index:10}.topbar--admin{z-index:20}.traffic-lights{display:flex;gap:7px;margin-right:4px}.light{width:12px;height:12px;border-radius:50%}.light--red{background:#ff5f56}.light--yellow{background:#ffbd2e}.light--green{background:#27c93f}.topbar-divider{width:1px;height:22px;background:var(--border-med)}.topbar-brand{font-family:var(--font-serif);font-style:italic;font-size:16px;font-weight:600;color:var(--text)}.topbar-project{padding:4px 10px}.topbar-project,.topbar-select{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);background:var(--surface-2);border:1px solid var(--border);border-radius:6px}.topbar-select{padding:4px 26px 4px 10px;outline:none;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239A9A9A' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;max-width:220px;overflow:hidden;text-overflow:ellipsis;transition:border-color .15s var(--ease)}.topbar-select:hover{border-color:var(--border-med);color:var(--text)}.admin-badge{font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;padding:3px 8px;border-radius:var(--radius-pill);background:var(--accent-dim);color:var(--accent);border:1px solid rgba(167,139,250,.25)}.topbar-right{margin-left:auto;gap:10px}.live-badge,.topbar-right{display:flex;align-items:center}.live-badge{gap:6px;font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-pill);padding:4px 10px 4px 8px}.live-dot{width:6px;height:6px;border-radius:50%;background:var(--success);animation:pulse 2.4s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.user-pill{font-family:var(--font-mono);font-size:10px;color:var(--text-muted);letter-spacing:.04em}.signout-btn{background:none;border:1px solid var(--border-med);color:var(--text-muted);border-radius:var(--radius-pill);font-family:var(--font-sans);font-size:12px;font-weight:500;padding:5px 13px;cursor:pointer;transition:all .15s var(--ease)}.signout-btn:hover{color:var(--text);border-color:var(--text);background:var(--surface-2)}.project-bar{height:40px;background:var(--bg);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:10px;flex-shrink:0}.project-bar-label{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-faint)}.project-bar-select{background:#fff;border:1px solid var(--border-med);border-radius:6px;font-family:var(--font-sans);font-size:13px;color:var(--text);padding:4px 10px;outline:none;cursor:pointer}.main{overflow:hidden}.main,.preview-pane{display:flex;flex:1 1}.preview-pane{flex-direction:column;border-right:1px solid var(--border-med)}.preview-chrome{height:36px;background:var(--surface);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 14px;gap:8px;flex-shrink:0}.chrome-dot{width:8px;height:8px;border-radius:50%;background:var(--border-med)}.chrome-url{flex:1 1;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-pill);height:22px;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:10px;color:var(--text-muted);max-width:280px;margin:0 auto;padding:0 12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-frame{flex:1 1;width:100%;border:none;display:block;background:#fff}.state-screen{flex:1 1;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px;text-align:center;padding:40px}.state-title{font-family:var(--font-serif);font-style:italic;font-size:20px;color:var(--text-muted)}.state-sub{font-family:var(--font-mono);font-size:11px;color:var(--text-faint);line-height:1.7}.comment-pane{width:360px;flex-shrink:0;display:flex;flex-direction:column;background:var(--bg)}.panel-header{padding:20px 22px 18px}.panel-header,.panel-header--row{border-bottom:1px solid var(--border);background:var(--surface);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);flex-shrink:0}.panel-header--row{padding:16px 22px;display:flex;align-items:center;justify-content:space-between}.panel-title{font-size:18px;color:var(--text);line-height:1.1;margin-bottom:3px}.panel-title,.panel-title--sm{font-family:var(--font-serif);font-style:italic;font-weight:600}.panel-title--sm{font-size:17px}.panel-sub{font-size:12px;color:var(--text-muted)}.comment-form{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:11px}.field-label{font-family:var(--font-mono);font-size:9px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);display:block;margin-bottom:5px}.field-group{display:flex;flex-direction:column}.form-field{background:#fff;border:1px solid var(--border-med);border-radius:6px;color:var(--text);font-family:var(--font-sans);font-size:13px;padding:9px 11px;outline:none;transition:border-color .18s var(--ease),box-shadow .18s var(--ease);width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-field:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.form-field--error{border-color:var(--danger);box-shadow:0 0 0 3px rgba(239,68,68,.1)}.form-field::placeholder{color:var(--text-faint)}.form-textarea{resize:none;height:82px;line-height:1.55}.form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px}.select-wrap{position:relative}.select-wrap:after{content:"▾";position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--text-faint);font-size:10px;pointer-events:none}.select-wrap .form-field{padding-right:26px;cursor:pointer}.comment-submit-btn{background:var(--text);color:#fff;border:1px solid var(--text);border-radius:var(--radius-pill);font-family:var(--font-sans);font-size:13px;font-weight:500;padding:10px;cursor:pointer;transition:all .2s var(--ease);width:100%}.comment-submit-btn:hover:not(:disabled){background:#333;border-color:#333;transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.12)}.comment-submit-btn:disabled{opacity:.45;cursor:not-allowed}.submit-hint{font-family:var(--font-mono);font-size:9px;color:var(--text-faint);text-align:center;letter-spacing:.04em}.comments-section{flex:1 1;overflow-y:auto;padding:16px 22px 24px}.comments-section--sm{padding:14px 20px 24px}.comments-section::-webkit-scrollbar{width:3px}.comments-section::-webkit-scrollbar-thumb{background:var(--border-med);border-radius:10px}.comments-empty{flex-direction:column;padding:44px 0;gap:12px;opacity:.45}.comments-empty,.empty-ring{display:flex;align-items:center}.empty-ring{width:36px;height:36px;justify-content:center}.empty-ring,.empty-ring-inner{border-radius:50%;border:1.5px solid var(--text-faint)}.empty-ring-inner{width:10px;height:10px}.comments-empty-text{font-family:var(--font-mono);font-size:10px;color:var(--text-faint);text-align:center;line-height:1.7}.comments-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.comments-count{font-weight:500;letter-spacing:.08em;text-transform:uppercase}.comments-count,.comments-resolved-count{font-family:var(--font-mono);font-size:10px;color:var(--text-faint)}.comment-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-card);padding:13px 14px;margin-bottom:9px;transition:box-shadow .2s var(--ease),border-color .2s var(--ease);animation:slideIn .18s var(--ease)}@keyframes slideIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.comment-card:hover{border-color:var(--border-med);box-shadow:0 4px 16px rgba(0,0,0,.06)}.comment-card.is-resolved{opacity:.5}.comment-meta{display:flex;align-items:center;gap:6px;margin-bottom:9px;flex-wrap:wrap}.commenter-name{font-weight:600;color:var(--text-muted);letter-spacing:.04em}.commenter-name,.tag{font-family:var(--font-mono);font-size:9px}.tag{font-weight:500;letter-spacing:.06em;padding:2px 7px;border-radius:4px;text-transform:uppercase}.tag-design{background:rgba(167,139,250,.12);color:#7c3aed}.tag-content{background:rgba(56,189,248,.12);color:#0284c7}.tag-bug{background:rgba(239,68,68,.12);color:#dc2626}.tag-ux{background:rgba(16,185,129,.12);color:#059669}.tag-general{background:var(--surface-3);color:var(--text-muted)}.priority-high{background:rgba(239,68,68,.1);color:#dc2626}.priority-medium{background:rgba(245,158,11,.1);color:#b45309}.priority-low{background:rgba(16,185,129,.1);color:#059669}.comment-time{font-family:var(--font-mono);font-size:9px;color:var(--text-faint);margin-left:auto;white-space:nowrap}.comment-text{font-size:13px;line-height:1.6;color:var(--text)}.comment-page-ref{font-family:var(--font-mono);font-size:10px;color:var(--text-muted);margin-top:7px}.admin-note-box{margin-top:9px;padding:8px 10px;background:rgba(167,139,250,.07);border-left:2px solid var(--accent);border-radius:0 4px 4px 0;font-size:12px;color:var(--text-muted);line-height:1.5}.admin-note-label{font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);display:block;margin-bottom:3px}.comment-footer{margin-top:9px;padding-top:8px;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px}.action-btn.danger:hover{color:var(--danger);border-color:rgba(239,68,68,.3);background:rgba(239,68,68,.05)}.comment-icon-actions{margin-left:auto;display:flex;gap:4px;align-items:center}.icon-btn{background:none;border:none;cursor:pointer;width:26px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--text-faint);transition:all .13s var(--ease);padding:0;flex-shrink:0}.check-btn:hover{color:#059669;background:rgba(16,185,129,.1)}.check-btn.is-done{color:#059669}.check-btn.is-done:hover{color:var(--text-faint);background:var(--surface-2)}.trash-btn:hover{color:var(--danger);background:rgba(239,68,68,.08)}.status-pill{font-family:var(--font-mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;padding:2px 8px;border-radius:var(--radius-pill)}.status-open{background:rgba(245,158,11,.1);color:#b45309;border:1px solid rgba(245,158,11,.2)}.status-resolved{background:rgba(16,185,129,.1);color:#059669;border:1px solid rgba(16,185,129,.2)}.page-body-layout{display:flex;flex:1 1;overflow:hidden}.sidebar{width:260px;border-right:1px solid var(--border-med);flex-direction:column;background:var(--bg)}.sidebar,.sidebar-header{flex-shrink:0;display:flex}.sidebar-header{padding:16px 18px;border-bottom:1px solid var(--border);align-items:center;justify-content:space-between}.sidebar-title{font-family:var(--font-mono);font-size:9px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint)}.new-project-btn{background:var(--text);color:#fff;border:none;border-radius:var(--radius-pill);font-family:var(--font-sans);font-size:11px;font-weight:500;padding:5px 12px;cursor:pointer;transition:all .15s var(--ease)}.new-project-btn:hover{background:#333;transform:translateY(-1px)}.sidebar-list{flex:1 1;overflow-y:auto;padding:8px 0}.sidebar-list::-webkit-scrollbar{width:3px}.sidebar-list::-webkit-scrollbar-thumb{background:var(--border-med);border-radius:10px}.sidebar-empty{display:flex;flex-direction:column;align-items:center;padding:40px 20px;gap:8px;opacity:.45;text-align:center}.sidebar-empty-text{font-family:var(--font-mono);font-size:10px;color:var(--text-faint);line-height:1.7}.project-item{padding:12px 18px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .12s var(--ease)}.project-item:hover{background:rgba(0,0,0,.025)}.project-item.active{background:rgba(167,139,250,.07);border-left:2px solid var(--accent);padding-left:16px}.project-item-name{font-size:13px;font-weight:500;color:var(--text);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-item-client{font-family:var(--font-mono);font-size:10px;color:var(--text-muted);margin-bottom:6px}.project-item-stats{display:flex;gap:8px}.stat-chip{font-family:var(--font-mono);font-size:9px;padding:1px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.04em}.stat-open{background:rgba(245,158,11,.1);color:#b45309}.stat-resolved{background:rgba(16,185,129,.1);color:#059669}.stat-none{background:var(--surface-3);color:var(--text-faint)}.empty-state{flex:1 1;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px;text-align:center;padding:40px;opacity:.45}.empty-state-title{font-family:var(--font-serif);font-style:italic;font-size:20px;color:var(--text-muted)}.empty-state-sub{font-family:var(--font-mono);font-size:11px;color:var(--text-faint);line-height:1.7}.filter-row{display:flex;gap:6px}.filter-btn{font-family:var(--font-mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;padding:3px 8px;border-radius:var(--radius-pill);border:1px solid var(--border-med);background:none;color:var(--text-faint);cursor:pointer;transition:all .12s var(--ease)}.filter-btn.active{background:var(--text);color:#fff;border-color:var(--text)}.comment-actions{display:flex;align-items:center;gap:6px;margin-top:10px;padding-top:9px;border-top:1px solid var(--border);opacity:0;transition:opacity .15s;flex-wrap:wrap}.comment-card:hover .comment-actions{opacity:1}.status-pill--left{margin-right:auto}.action-btn{background:none;border:1px solid var(--border-med);color:var(--text-muted);cursor:pointer;font-family:var(--font-sans);font-size:11px;font-weight:500;padding:3px 10px;border-radius:var(--radius-pill);transition:all .13s var(--ease)}.action-btn:hover{background:var(--surface-2);color:var(--text);border-color:var(--text)}.action-btn.resolve-btn:hover{background:rgba(16,185,129,.08);color:#059669;border-color:rgba(16,185,129,.4)}.note-form{margin-top:10px;gap:8px;flex-direction:column;display:flex}.note-textarea{width:100%;background:var(--bg);border:1px solid var(--border-med);border-radius:6px;font-family:var(--font-sans);font-size:12px;color:var(--text);padding:8px 10px;outline:none;resize:none;height:64px;transition:border-color .15s var(--ease),box-shadow .15s var(--ease)}.note-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-dim)}.note-actions{display:flex;gap:6px}.note-save-btn{background:var(--text);color:#fff;border:none;border-radius:var(--radius-pill);font-family:var(--font-sans);font-size:11px;font-weight:500;padding:5px 12px;cursor:pointer;transition:all .13s var(--ease)}.note-save-btn:hover{background:#333}.note-cancel-btn{background:none;border:1px solid var(--border-med);color:var(--text-muted);border-radius:var(--radius-pill);font-family:var(--font-sans);font-size:11px;font-weight:500;padding:5px 12px;cursor:pointer;transition:all .13s var(--ease)}.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.3);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;align-items:center;justify-content:center}.modal-overlay.open{display:flex}.modal{background:#fff;border:1px solid var(--border);border-radius:16px;width:440px;max-width:calc(100vw - 40px);box-shadow:0 20px 60px rgba(0,0,0,.12);animation:modalIn .2s var(--ease)}@keyframes modalIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.modal-title{font-family:var(--font-serif);font-style:italic;font-size:20px;font-weight:600}.modal-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:20px;line-height:1;padding:4px;border-radius:6px;transition:all .12s var(--ease)}.modal-close:hover{color:var(--text);background:var(--surface-2)}.modal-body{padding:20px 24px 24px;gap:14px}.modal-body,.modal-field-group{display:flex;flex-direction:column}.modal-field-group{gap:5px}.modal-label{font-family:var(--font-mono);font-size:9px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint)}.modal-input{background:var(--bg);border:1px solid var(--border-med);border-radius:8px;color:var(--text);font-family:var(--font-sans);font-size:13px;padding:9px 12px;outline:none;width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;transition:border-color .15s var(--ease),box-shadow .15s var(--ease)}.modal-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.modal-input::placeholder{color:var(--text-faint)}.modal-submit{width:100%;background:var(--text);color:#fff;border:none;border-radius:var(--radius-pill);font-family:var(--font-sans);font-size:13px;font-weight:500;padding:11px;cursor:pointer;margin-top:2px;transition:all .2s var(--ease)}.modal-submit:hover:not(:disabled){background:#333;transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.12)}.modal-submit:disabled{opacity:.5;cursor:not-allowed}.modal-error{font-size:12px;color:var(--danger);text-align:center}