*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary:#fff;--bg-secondary:#f9fafb;--bg-tertiary:#ececec;--text-primary:#0d0d0d;--text-secondary:#676767;--text-tertiary:#9ca3af;--border:#e5e7eb;--sidebar-bg:#f9f9f9;--accent:#2563eb;--accent-hover:#1d4ed8;--accent-light:rgba(37,99,235,.08);--danger:#dc2626;--danger-hover:#b91c1c;--warning:#f59e0b;--warning-light:#fef3c7;--warning-dark:#92400e;--error:#dc2626;--error-light:#fef2f2;--surface-primary:#fff;--surface-secondary:#f9fafb;--border-color:#e5e7eb}@media (prefers-color-scheme:dark){:root{--bg-primary:#1e1e1e;--bg-secondary:#2c2c2c;--bg-tertiary:#3a3a3a;--text-primary:#f5f5f7;--text-secondary:#a1a1a6;--text-tertiary:#6e6e73;--border:#3a3a3a;--sidebar-bg:#161616;--accent:#3b82f6;--accent-hover:#60a5fa;--accent-light:rgba(59,130,246,.15);--danger:#ff453a;--danger-hover:#ff3b30;--warning:#f59e0b;--warning-light:#451a03;--warning-dark:#fcd34d;--error:#ff453a;--error-light:#450a0a;--surface-primary:#1e1e1e;--surface-secondary:#2c2c2c;--border-color:#3a3a3a}}html{text-size-adjust:100%}body,html{height:100%;width:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans,Helvetica,Arial,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;margin:0;padding:0;position:fixed;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.loading{color:var(--text-secondary)}.error-boundary,.loading{display:flex;align-items:center;justify-content:center;height:100vh}.error-boundary{background:var(--bg-secondary);padding:1rem}.error-boundary-content{background:var(--bg-primary);padding:2.5rem;border-radius:12px;border:1px solid var(--border);text-align:center;max-width:400px;width:100%}.error-boundary-content svg{color:var(--danger);margin-bottom:1rem}.error-boundary-content h2{font-size:1.5rem;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}.error-boundary-content p{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.875rem}.error-boundary-content details{text-align:left;margin-bottom:1.5rem;padding:1rem;background:var(--bg-secondary);border-radius:6px;font-size:.75rem}.error-boundary-content details summary{cursor:pointer;color:var(--text-secondary);margin-bottom:.5rem}.error-boundary-content details pre{white-space:pre-wrap;word-break:break-word;color:var(--danger);margin:0}.error-boundary-actions{display:flex;gap:.75rem;justify-content:center}.error-boundary-actions button{padding:.625rem 1.25rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s}.btn-secondary{background:var(--bg-secondary)}.btn-secondary:hover{background:var(--bg-tertiary)}.auth-container{height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);overflow:hidden}.auth-box{background:var(--bg-primary);padding:2.5rem;border-radius:8px;border:1px solid var(--border);width:90%;max-width:400px}.auth-box h1{font-size:1.75rem;font-weight:600;margin-bottom:.5rem;text-align:center}.auth-box-wide{max-width:520px}.success-icon{font-size:3rem;text-align:center;margin-bottom:1rem;color:#22c55e}.button-group{display:flex;gap:.75rem;margin-top:1.5rem}.button-group .btn-secondary{flex:1 1}.button-group .btn-primary{flex:2 1}.auth-box p{color:var(--text-secondary);text-align:center;margin-bottom:2rem;font-size:.875rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-size:.875rem;font-weight:500}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:6px;font-size:1rem;font-family:inherit;background:var(--bg-primary);color:var(--text-primary);transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent)}.form-group textarea{resize:none;min-height:80px;max-height:400px;overflow-y:auto}.btn-primary{background:var(--accent);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:background-color .2s;display:inline-flex;align-items:center;gap:.5rem}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:transparent;color:var(--text-primary);border:1px solid var(--border);padding:.75rem 1.5rem;border-radius:6px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-secondary:hover{background:var(--bg-secondary)}.btn-secondary.active{background:var(--accent);color:#fff;border-color:var(--accent)}.calendar-picker{width:100%}.date-display-btn{width:100%;padding:1rem 1.25rem;border:1px solid var(--border);border-radius:6px;background:var(--bg-secondary);font-family:inherit;font-size:1rem;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all .2s;text-align:left}.date-display-btn:hover{border-color:var(--accent)}.year-grid{display:grid;grid-template-columns:repeat(5,1fr);grid-gap:.5rem;gap:.5rem;margin-bottom:1rem}.year-btn{background:var(--bg-secondary);border:1px solid var(--border);padding:.75rem;border-radius:6px;font-family:inherit;font-size:.9375rem;font-weight:400;color:var(--text-primary);cursor:pointer;transition:all .2s}.year-btn.active,.year-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.month-selector-btn{width:100%;background:var(--bg-secondary);border:1px solid var(--border);padding:.75rem 1rem;border-radius:6px;font-family:inherit;font-size:.9375rem;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all .2s;display:flex;justify-content:space-between;align-items:center}.month-selector-btn:hover{border-color:var(--accent)}.month-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:.5rem;gap:.5rem}.month-btn{background:var(--bg-secondary);border:1px solid var(--border);padding:.75rem;border-radius:6px;font-family:inherit;font-size:.9375rem;font-weight:400;color:var(--text-primary);cursor:pointer;transition:all .2s}.month-btn.active,.month-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.day-names{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:.25rem;gap:.25rem;margin-bottom:.5rem}.day-name{text-align:center;font-family:inherit;font-size:.75rem;font-weight:500;color:var(--text-secondary);padding:.25rem}.day-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:.25rem;gap:.25rem}.day-btn{background:var(--bg-secondary);border:1px solid var(--border);padding:.75rem;border-radius:6px;font-family:inherit;font-size:.875rem;font-weight:400;color:var(--text-primary);cursor:pointer;transition:all .2s;aspect-ratio:1;display:flex;align-items:center;justify-content:center}.day-btn.active,.day-btn:hover:not(.empty){background:var(--accent);color:#fff;border-color:var(--accent)}.day-btn.empty{background:transparent;border:none;cursor:default}.auth-switch{margin-top:1.5rem;text-align:center;font-size:.875rem;color:var(--text-secondary)}.auth-switch button{background:none;border:none;color:var(--accent);cursor:pointer;font-weight:500;padding:0}.auth-switch button:hover{text-decoration:underline}.encryption-notice{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border);font-size:.8125rem;color:var(--text-secondary)}.encryption-notice .lock-icon{font-size:.875rem}.error-message{background:rgba(255,69,58,.1);color:var(--danger);border-radius:6px;border:1px solid var(--danger)}.error-message,.success-message{padding:.75rem;margin-bottom:1rem;font-size:.875rem}.success-message{background:rgba(34,197,94,.1);color:#22c55e;border-radius:6px;border:1px solid #22c55e}.app{height:100%;width:100%;overflow:hidden}.app,.sidebar{display:flex;position:relative}.sidebar{width:280px;min-width:200px;max-width:600px;background:var(--sidebar-bg);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0}.sidebar-resize-handle.style-line{position:absolute;top:0;right:0;width:8px;height:100%;cursor:col-resize;z-index:10}.sidebar-resize-handle.style-line:before{content:"";position:absolute;top:0;left:3px;width:2px;height:100%;background:var(--border);transition:all .15s}.sidebar-resize-handle.style-line:hover:before{width:3px;left:2px;background:var(--accent)}.sidebar-resize-handle.style-notch{position:absolute;top:0;right:-8px;width:16px;height:100%;cursor:col-resize;z-index:10}.sidebar-resize-handle.style-notch:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:6px;height:48px;background:transparent;border:1px solid transparent;border-radius:3px;transition:all .15s;opacity:0}.sidebar-resize-handle.style-notch:hover:before{background:var(--bg-tertiary);border-color:var(--border);height:64px;opacity:1}.sidebar-resize-handle.style-notch:active:before{background:var(--text-tertiary)}.sidebar-resize-handle.style-figma{position:absolute;top:0;right:-2px;width:6px;height:100%;cursor:col-resize;z-index:10}.sidebar-resize-handle.style-figma:before{content:"";position:absolute;top:0;left:2px;width:2px;height:100%;background:transparent;transition:all .1s}.sidebar-resize-handle.style-figma:hover:before{background:var(--accent);width:3px;left:1px}.sidebar-header{padding:1rem;border-bottom:1px solid var(--border);flex-shrink:0;display:flex;flex-direction:column;gap:.5rem;overflow:visible}.sidebar-search{width:100%;padding:.5rem .75rem;border:1px solid var(--border);border-radius:6px;font-size:1rem;font-family:inherit;background:var(--bg-primary);color:var(--text-primary);transition:border-color .2s}.sidebar-search:focus{outline:none;border-color:var(--accent)}.sidebar-search::placeholder{color:var(--text-secondary)}.sort-tabs{display:flex;gap:2px}.sort-tab{flex:1 1;padding:.375rem 0;background:transparent;border:none;border-radius:8px;font-size:.75rem;font-weight:500;font-family:inherit;color:var(--text-secondary);cursor:pointer;transition:all .15s;white-space:nowrap}.sort-tab:hover{color:var(--text-primary)}.sort-tab.active{background:var(--text-primary);color:var(--bg-primary)}.sidebar-filter-row{display:flex;align-items:center;gap:4px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.sidebar-filter-row::-webkit-scrollbar{display:none}.tag-filter-pills{display:flex;flex-wrap:nowrap;gap:.375rem;overflow-x:auto;max-height:none;scrollbar-width:none;-ms-overflow-style:none}.tag-filter-pills::-webkit-scrollbar{display:none}.tag-pill{padding:.25rem .625rem;font-size:.6875rem;font-weight:500;border-radius:999px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;transition:all .15s;white-space:nowrap}.tag-pill:hover{border-color:var(--text-secondary);color:var(--text-primary)}.tag-pill.active{background:var(--text-primary);border-color:var(--text-primary);color:var(--bg-primary)}.sidebar-content{flex:1 1;overflow-y:auto;min-height:0}.sidebar-empty{padding:1rem .75rem;text-align:center;color:var(--text-secondary);font-size:.875rem}.sidebar-section{padding:1rem}.sidebar-section-title{font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--text-secondary);margin-bottom:.75rem;letter-spacing:.05em}.sidebar-item{display:flex;align-items:center;gap:.625rem;padding:.5rem .625rem;margin-bottom:.125rem;border-radius:8px;cursor:pointer;transition:background-color .15s}.sidebar-item:hover{background:var(--bg-secondary)}.sidebar-item-active{background:rgba(0,122,255,.08)}@media (prefers-color-scheme:dark){.sidebar-item-active{background:rgba(10,132,255,.15)}}.sidebar-item-avatar{width:32px;height:32px;border-radius:8px;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.6875rem;font-weight:600;flex-shrink:0}.sidebar-item-content{flex:1 1;min-width:0}.sidebar-item-top-row{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem}.sidebar-item-name{font-size:.8125rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-item-date{font-size:.6875rem;flex-shrink:0}.sidebar-item-date,.sidebar-item-desc{color:var(--text-tertiary);white-space:nowrap}.sidebar-item-desc{font-size:.75rem;overflow:hidden;text-overflow:ellipsis;margin-top:.0625rem}.sidebar-footer{border-top:1px solid var(--border);padding:.75rem 1rem;gap:.5rem}.sidebar-footer,.sidebar-footer-btn{display:flex;align-items:center;justify-content:space-between}.sidebar-footer-btn{width:100%;padding:.75rem;background:transparent;border:none;border-radius:6px;cursor:pointer;color:var(--text-secondary);font-size:.875rem;transition:background-color .15s}.sidebar-footer-btn:hover{background:var(--bg-secondary)}.sidebar-footer-user{font-size:.8125rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1 1}.sidebar-footer-actions{display:flex;gap:.25rem;flex-shrink:0}.sidebar-footer-icon-btn{padding:.5rem;background:transparent;border:none;border-radius:6px;cursor:pointer;color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;transition:all .15s ease}.sidebar-footer-icon-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.sidebar-footer-icon-btn:disabled{opacity:.5;cursor:not-allowed}.main-content{display:flex;flex-direction:column;height:100%;width:100%;overflow:hidden}.main-header{padding:1rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:1rem;background:var(--bg-primary);flex-shrink:0}.main-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);flex:1 1;text-align:center}.new-person-btn{background:transparent;border:none;padding:.5rem;cursor:pointer;color:var(--text-primary);border-radius:6px;transition:all .2s;display:flex;align-items:center;justify-content:center}.new-person-btn:hover{background:var(--bg-secondary)}.show-on-mobile{display:none!important}.people-list-view{flex:1 1;display:flex;flex-direction:column;overflow:hidden}.suggested-contacts-section{padding:1.5rem 2rem .5rem;max-width:48rem;margin:0 auto;width:100%}.suggested-contacts-header{margin-bottom:.75rem}.suggested-contacts-header h3{font-size:.8125rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.suggested-contacts-list{display:flex;flex-direction:column;gap:.5rem}.suggested-contact-item{display:flex;align-items:center;justify-content:space-between;background:var(--bg-primary);padding:.875rem 1rem;border-radius:10px;border:1px solid var(--border);cursor:pointer;transition:all .2s}.suggested-contact-item:hover{background:var(--bg-secondary);border-color:var(--border-hover)}.suggested-contact-info{flex:1 1;min-width:0}.suggested-contact-name{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:.125rem}.suggested-contact-summary{font-size:.8125rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.suggested-contact-reason{font-size:.75rem;color:var(--text-secondary);display:flex;align-items:center;gap:.375rem}.suggestion-icon{font-size:.75rem}.dismiss-suggestion-btn{background:none;border:none;padding:.5rem;cursor:pointer;color:var(--text-tertiary);border-radius:6px;transition:all .2s;flex-shrink:0;margin-left:.5rem}.dismiss-suggestion-btn:hover{background:var(--bg-tertiary);color:var(--text-secondary)}.activity-feed{flex:1 1;overflow-y:auto;display:flex;flex-direction:column}.ai-tasks-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem .5rem;max-width:48rem;margin:0 auto;width:100%}.ai-tasks-title{font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.add-task-btn{padding:6px 12px;background:var(--accent);color:#fff;border:none;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;transition:opacity .2s}.add-task-btn:hover{opacity:.9}.activity-feed-header{padding:2rem 2rem 1rem;max-width:48rem;margin:0 auto;width:100%}.activity-feed-header h2{font-size:1.5rem;font-weight:600;color:var(--text-primary)}.activity-list{flex:1 1;padding:0 2rem 2rem;max-width:48rem;margin:0 auto;width:100%;display:flex;flex-direction:column;gap:.75rem}.activity-item{background:var(--bg-primary);padding:1.25rem;border-radius:12px;border:1px solid var(--border);cursor:pointer;transition:all .2s}@media (hover:hover) and (pointer:fine){.activity-item:hover{background:var(--bg-secondary);transform:translateY(-1px)}}.activity-item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.625rem;gap:1rem}.activity-item-name{font-size:1.125rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.activity-item-date{font-size:.75rem;color:var(--text-tertiary);font-weight:400;white-space:nowrap;padding-top:.125rem}.activity-item-notes{font-size:.9375rem;color:var(--text-secondary);line-height:1.6;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.staging-grid-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 2rem;max-width:72rem;margin:0 auto;width:100%}.staging-grid-count{font-size:.875rem;color:var(--text-secondary)}.people-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:1rem;gap:1rem;padding:0 2rem 2rem;max-width:72rem;margin:0 auto;width:100%}.person-card{background:var(--bg-primary);padding:1.25rem;border-radius:12px;border:1px solid var(--border);cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:.5rem}@media (hover:hover) and (pointer:fine){.person-card:hover{background:var(--bg-secondary);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.1)}}.person-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.person-card-name{font-size:1.0625rem;font-weight:600;color:var(--text-primary);line-height:1.3}.person-card-date{font-size:.75rem;color:var(--text-secondary);white-space:nowrap;flex-shrink:0}.person-card-tags{display:flex;flex-wrap:nowrap;gap:.375rem;margin-top:.25rem;overflow:hidden}.person-card-tag{border-radius:999px;border:1px solid var(--border);background:var(--bg-secondary);font-weight:500}.person-card-tag,.person-card-tag-more{font-size:.6875rem;padding:.1875rem .5rem;color:var(--text-secondary)}.person-card-tag-more{flex-shrink:0}.person-card-summary{font-size:.875rem;color:var(--text-secondary);line-height:1.5;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:.25rem}.person-card-suggested{border-color:var(--accent);background:linear-gradient(135deg,rgba(99,102,241,.03),rgba(99,102,241,.08))}.person-card-suggested-badge{font-size:.6875rem;padding:.125rem .5rem;background:var(--accent);color:#fff;border-radius:999px;font-weight:500;white-space:nowrap}@media (max-width:640px){.staging-grid-header{padding:.75rem 1rem}.people-card-grid{grid-template-columns:1fr;padding:0 1rem 1rem}}.skeleton-activity-item{background:var(--bg-primary);padding:1.25rem;border-radius:12px;border:1px solid var(--border);margin-bottom:.75rem}.skeleton-activity-item .skeleton.skeleton-name{height:16px;width:120px;margin-bottom:10px}.skeleton-activity-item .skeleton.skeleton-desc{height:14px;width:200px;margin-bottom:10px}.skeleton-activity-item .skeleton.skeleton-date,.skeleton-date{height:12px;width:80px}.search-bar-container{padding:1rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg-primary);flex-shrink:0;display:none}.search-input{width:100%;max-width:600px;margin:0 auto;display:block;padding:.75rem 1rem;border:1px solid var(--border);border-radius:8px;font-size:1rem;font-family:inherit;background:var(--bg-primary);color:var(--text-primary);transition:border-color .2s,box-shadow .2s}.search-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(16,163,127,.1)}.search-input::placeholder{color:var(--text-secondary)}.people-list{flex:1 1;overflow-y:auto;padding:1rem 0;display:none}.person-item{max-width:600px;margin:0 auto .75rem;padding:1rem 1.5rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:12px;cursor:pointer;transition:all .2s;display:flex;align-items:flex-start;gap:.875rem}.person-item-avatar{width:40px;height:40px;border-radius:10px;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.8125rem;font-weight:600;flex-shrink:0}.person-item-content{flex:1 1;min-width:0}@media (hover:hover) and (pointer:fine){.person-item:hover{border-color:var(--accent);box-shadow:0 2px 8px rgba(0,0,0,.08);transform:translateY(-1px)}}.person-item-name{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin-bottom:.375rem;letter-spacing:-.01em}.person-item-desc{font-size:.9375rem;color:var(--text-secondary);margin-bottom:.625rem;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.5}.person-item-date{font-size:.75rem;color:var(--text-tertiary);font-weight:400}.skeleton-person-item{max-width:600px;margin:0 auto .75rem;padding:1rem 1.5rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:12px}.skeleton-person-item .skeleton.skeleton-name{height:16px;width:120px;margin-bottom:10px}.skeleton-person-item .skeleton.skeleton-desc{height:14px;width:180px}.footer-container{border-top:1px solid var(--border);padding:1rem 1.5rem;background:var(--bg-primary);flex-shrink:0;display:none}.mobile-fab{display:none}.footer-signout-btn{max-width:600px;margin:0 auto;width:100%;display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:background-color .2s}.footer-signout-btn:hover{background:var(--bg-secondary)}.footer-signout-btn span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tag{display:inline-flex;align-items:center;padding:.25rem .75rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:999px;font-size:.8125rem;color:var(--text-primary);white-space:nowrap}.tag-clickable{cursor:pointer;transition:background-color .15s,border-color .15s}.tag-clickable:hover{background:var(--bg-primary);border-color:var(--text-secondary)}.tag-add{cursor:pointer;background:transparent;border:1px dashed var(--border);color:var(--text-secondary);padding:.25rem .5rem;border-radius:999px;font-size:.875rem;transition:border-color .15s,color .15s}.tag-add:hover{border-color:var(--text-secondary);color:var(--text-primary)}.contact-detail-tag{display:inline-flex;align-items:center;gap:.125rem;font-size:.75rem;padding:.125rem .5rem;border-radius:999px;background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border);transition:background .2s ease,border-color .2s ease}.contact-detail-tag:hover{background:var(--bg-tertiary,rgba(0,0,0,.06));border-color:var(--text-secondary)}.contact-detail-tag-x{display:inline-flex;align-items:center;justify-content:center;width:0;height:14px;border-radius:50%;border:none;padding:0;margin:0;background:transparent;color:var(--text-secondary);cursor:pointer;opacity:0;overflow:hidden;transition:width .2s ease,opacity .15s ease,margin .2s ease,background .15s ease}.contact-detail-tag:hover .contact-detail-tag-x{width:14px;margin-left:.125rem;opacity:.6}.contact-detail-tag-x:hover{opacity:1!important;background:rgba(0,0,0,.1)}.tag-delete{display:none;margin-left:.375rem;background:none;border:none;color:var(--danger);cursor:pointer;font-size:.75rem;padding:0;line-height:1}.tag:hover .tag-delete{display:inline-flex}.tags-row{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.75rem 1rem;border-bottom:1px solid var(--border)}.relationship-popover{position:absolute;top:100%;left:0;margin-top:.5rem;padding:1rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.15);z-index:100;min-width:280px}@media (max-width:768px){body,html{overflow-x:hidden!important;width:100%;max-width:100vw;overscroll-behavior-x:none}.app,.main-content{max-width:100vw;overflow-x:hidden;width:100%}.relationship-popover{min-width:auto;max-width:calc(100vw - 2rem);left:0;right:0;margin-left:auto;margin-right:auto}.tags-row{max-width:100%;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}.activity-feed,.sidebar{display:none}.hide-on-mobile{display:none!important}.show-on-mobile{display:flex!important}.search-bar-container{display:flex;align-items:center;padding:.75rem 1rem}.people-list{display:block;padding:.75rem 0;animation:slideInFromRight .25s ease-out}.footer-container{display:block;padding:.75rem 1rem}.main-header{padding:.75rem 1rem;flex-shrink:0;position:-webkit-sticky;position:sticky;top:0;z-index:100;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:hsla(0,0%,100%,.9)}.main-title{font-size:1.0625rem;font-weight:600}.contact-detail-view{animation:slideInFromRight .25s ease-out}@keyframes slideInFromRight{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}.suggested-contacts-section{padding:1rem;max-width:100%}.suggested-contact-item{max-width:100%}.person-item{margin:0 1rem .75rem;padding:1rem}.person-item-name{font-size:1rem}.skeleton-person-item{margin:0 1rem .75rem;padding:1rem}.empty-state{padding:1.5rem 1rem}.empty-state h1{font-size:1.5rem}.empty-state p{font-size:.9375rem}.contact-detail-view{padding:1rem;max-width:100vw;overflow-x:hidden}.contact-detail-info{max-width:100%;padding:1.5rem;overflow-wrap:break-word;word-wrap:break-word}.contact-interactions-section{max-width:100%;padding:0 .5rem;overflow-x:hidden}.modal-content{width:95%;margin:1rem;max-width:calc(100vw - 2rem)}.auth-box{padding:2rem 1.5rem}.back-btn{padding:.5rem .75rem}.icon-btn,.interaction-menu-btn,.new-person-btn{min-width:44px;min-height:44px}.btn-primary,.btn-secondary{min-height:44px}.sidebar-item{padding:.625rem .75rem}.contact-interaction-item{padding:1rem;max-width:100%;overflow-wrap:break-word;word-wrap:break-word}.contact-interaction-notes{overflow-wrap:break-word;word-wrap:break-word;word-break:break-word}.people-list-view{max-width:100vw;overflow-x:hidden}input,select,textarea{font-size:16px!important}}@media (max-width:768px) and (prefers-color-scheme:dark){.main-header{background:rgba(30,30,30,.9)}}.empty-state{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;overflow:hidden;min-height:0}.empty-state-icon{width:80px;height:80px;margin-bottom:1.5rem;color:var(--accent);opacity:.8}.empty-state h1{font-size:1.75rem;font-weight:600;margin-bottom:.75rem;color:var(--text-primary);letter-spacing:-.02em}.empty-state p{font-size:1rem;color:var(--text-secondary);max-width:320px;line-height:1.5}.empty-state-cta{margin-top:1.5rem}.empty-state-features{display:flex;flex-wrap:wrap;justify-content:center;gap:1.5rem;margin-top:2rem;max-width:480px}.empty-state-feature{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.empty-state-feature-icon{width:18px;height:18px;color:var(--accent);flex-shrink:0}.empty-state-search{padding:3rem 2rem}.empty-state-search-icon{width:48px;height:48px;margin-bottom:1rem;color:var(--text-tertiary)}.empty-state-search h2{font-size:1.25rem;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}.empty-state-search p{font-size:.9375rem;color:var(--text-secondary)}.interactions-container{flex:1 1;overflow-y:auto;padding:2rem 0;min-height:0}.interaction-message{max-width:48rem;margin:0 auto;padding:1.5rem 1rem;border-bottom:1px solid var(--border)}.interaction-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.interaction-contact{font-weight:600;color:var(--text-primary);font-size:.9375rem}.interaction-date{font-size:.8125rem;color:var(--text-secondary)}.interaction-content{color:var(--text-primary);font-size:1rem;line-height:1.75;white-space:pre-wrap}.input-container{border-top:1px solid var(--border);background:var(--bg-primary);padding:1rem}.input-form{max-width:48rem;margin:0 auto;position:relative}.input-wrapper-bottom{display:flex;align-items:flex-end;gap:.75rem;padding:.75rem 1rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:24px;transition:box-shadow .2s}.input-wrapper-bottom:focus-within{box-shadow:0 0 0 2px var(--border)}.input-wrapper-bottom textarea{flex:1 1;border:none;background:transparent;font-size:1rem;font-family:inherit;resize:none;outline:none;max-height:200px;overflow-y:auto;line-height:1.5}.input-wrapper-bottom textarea::placeholder{color:var(--text-secondary)}.send-btn{background:transparent;color:var(--accent);border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:opacity .2s}.send-btn:hover:not(:disabled){opacity:.7}.send-btn:disabled{opacity:.3;cursor:not-allowed}.modal{display:none;position:fixed;z-index:2000;left:0;top:0;width:100%;height:100%;background:rgba(0,0,0,.5)}.modal-overlay,.modal.show{display:flex;align-items:center;justify-content:center;animation:fadeIn .2s}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:2000;padding:1rem}.modal-content{background:var(--bg-secondary);border-radius:12px;width:90%;max-width:400px;box-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);animation:slideUp .2s}.modal-content.modal-large{max-width:600px;max-height:80vh;display:flex;flex-direction:column}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{padding:1.5rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start}.modal-header h3{font-size:1.125rem;font-weight:600}.modal-header-actions{display:flex;align-items:center;gap:.5rem}.close-btn{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;line-height:1;padding:0;width:30px;height:30px}.close-btn:hover{color:var(--text-primary)}.btn-danger-small{background:var(--danger);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-danger-small:hover{background:var(--danger-hover)}.icon-btn{background:transparent;border:none;color:var(--text-secondary);padding:.5rem;border-radius:6px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.icon-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.icon-btn-danger{background:transparent;border:none;color:var(--text-secondary);padding:.5rem;border-radius:6px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.icon-btn-danger:hover{background:var(--bg-secondary);color:var(--danger)}.modal-content form{padding:1.5rem}.modal-actions{justify-content:flex-end;margin-top:1.5rem}.form-row,.modal-actions{display:flex;gap:.75rem}.form-row .form-group{flex:1 1}.form-hint{font-size:.75rem;color:var(--text-tertiary);margin-top:.25rem;display:block}.contact-description{font-size:.875rem;color:var(--text-secondary);margin-top:.25rem;font-weight:400}.modal-body{padding:1.5rem;overflow-y:auto;flex:1 1}.modal-body h4{font-size:1rem;font-weight:600;margin-bottom:1rem;color:var(--text-primary)}.modal-interactions-list{display:flex;flex-direction:column;gap:1rem}.modal-interaction-item{padding:1rem;background:var(--bg-secondary);border-radius:8px}.modal-interaction-date{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.modal-interaction-notes{font-size:.9375rem;color:var(--text-secondary);white-space:pre-wrap;line-height:1.6}.contact-detail-view{flex:1 1;overflow-y:auto;padding:2rem;min-height:0}.contact-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;max-width:48rem;margin-left:auto;margin-right:auto;padding:0 1rem}.contact-detail-name{flex:1 1;text-align:center;font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0}.back-btn{display:flex;align-items:center;gap:.5rem;background:transparent;border:1px solid var(--border);padding:.5rem 1rem;border-radius:6px;color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.back-btn:hover{background:var(--bg-secondary)}.contact-detail-info{max-width:48rem;margin:0 auto 2rem;background:var(--bg-primary);padding:2rem;border-radius:12px;border:1px solid var(--border)}.contact-detail-info h2{font-size:1.75rem;font-weight:600;margin-bottom:.5rem}.contact-description-large{font-size:1rem;color:var(--text-secondary);line-height:1.6}.contact-interactions-section{max-width:48rem;margin:0 auto}.contact-interactions-section h3{font-size:1.125rem;font-weight:600;margin-bottom:1rem}.no-interactions{text-align:center;padding:2rem;color:var(--text-secondary);font-size:.9375rem}.contact-interactions-list{display:flex;flex-direction:column;gap:1rem}.contact-interaction-item{background:var(--bg-primary);padding:1.25rem;border-radius:12px;border:1px solid var(--border);transition:all .2s}.contact-interaction-item.clickable{cursor:pointer}@media (hover:hover) and (pointer:fine){.contact-interaction-item.clickable:hover{background:var(--bg-secondary);transform:translateY(-1px)}}.contact-interaction-item.highlighted{background:color-mix(in srgb,var(--accent) 8%,var(--bg-primary));border-color:var(--accent);animation:highlightPulse .5s ease-out}@keyframes highlightPulse{0%{background:color-mix(in srgb,var(--accent) 15%,var(--bg-primary))}to{background:color-mix(in srgb,var(--accent) 8%,var(--bg-primary))}}.contact-interaction-date{font-size:.75rem;font-weight:500;color:var(--text-tertiary);margin-bottom:.625rem;text-transform:uppercase;letter-spacing:.03em}.contact-interaction-notes{font-size:1rem;color:var(--text-primary);white-space:pre-wrap;line-height:1.7}.interaction-menu-btn{background:transparent;border:none;color:var(--text-secondary);padding:.25rem;border-radius:4px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.interaction-menu-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.interaction-menu{position:absolute;right:0;top:100%;margin-top:.25rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:6px;box-shadow:0 4px 12px rgba(0,0,0,.1);min-width:120px;z-index:100;overflow:hidden}.interaction-menu button{width:100%;padding:.5rem .75rem;background:transparent;border:none;text-align:left;font-size:.875rem;color:var(--text-primary);cursor:pointer;transition:background-color .2s}.interaction-menu button:hover{background:var(--bg-secondary)}.interaction-menu button.danger{color:var(--danger)}.interaction-menu button:not(:last-child){border-bottom:1px solid var(--border)}.contact-menu{position:absolute;right:0;top:100%;margin-top:.5rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:6px;box-shadow:0 4px 12px rgba(0,0,0,.1);min-width:120px;z-index:100;overflow:hidden}.contact-menu button{width:100%;padding:.5rem .75rem;background:transparent;border:none;text-align:left;font-size:.875rem;color:var(--text-primary);cursor:pointer;transition:background-color .2s}.contact-menu button:hover{background:var(--bg-secondary)}.contact-menu button.danger{color:var(--danger)}.contact-menu button:not(:last-child){border-bottom:1px solid var(--border)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:transparent;border-radius:4px;-webkit-transition:background .2s;transition:background .2s}:hover::-webkit-scrollbar-thumb{background:var(--bg-tertiary)}:hover::-webkit-scrollbar-thumb:hover{background:var(--border)}*{scrollbar-width:thin;scrollbar-color:transparent transparent}:hover{scrollbar-color:var(--bg-tertiary) transparent}@keyframes shimmer{0%{background-position:-468px 0}to{background-position:468px 0}}.skeleton{animation:shimmer 1.5s infinite;background:linear-gradient(to right,var(--bg-secondary) 0,var(--bg-tertiary) 20%,var(--bg-secondary) 40%,var(--bg-secondary) 100%);background-size:800px 100px;border-radius:6px}.skeleton-sidebar-item{display:flex;align-items:center;gap:.625rem;padding:.5rem .625rem;margin-bottom:.25rem}.skeleton-avatar{width:32px;height:32px;border-radius:8px;flex-shrink:0}.skeleton-sidebar-item-content{flex:1 1;min-width:0}.skeleton-name{height:14px;width:100px;margin-bottom:6px}.skeleton-desc{height:12px;width:160px}.skeleton-interaction{padding:1rem;margin-bottom:1rem;border-radius:8px;background:var(--bg-secondary)}.skeleton-interaction-date{height:12px;width:70px;margin-bottom:8px}.skeleton-interaction-content{height:14px;width:240px;margin-bottom:6px}.skeleton-interaction-content:last-child{width:160px;margin-bottom:0}.toast-container{position:fixed;top:1rem;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:.75rem;pointer-events:none}.toast{pointer-events:all;min-width:300px;max-width:500px;background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;padding:1rem;box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05);display:flex;align-items:center;justify-content:space-between;gap:1rem;animation:slideInRight .3s ease-out;cursor:pointer}@keyframes slideInRight{0%{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}.toast-content{display:flex;align-items:center;gap:.75rem;flex:1 1;font-size:.875rem}.toast-success{border-left:4px solid #10a37f;color:var(--text-primary)}.toast-success svg{color:#10a37f;flex-shrink:0}.toast-error{border-left:4px solid var(--danger);color:var(--text-primary)}.toast-error svg{color:var(--danger);flex-shrink:0}.toast-info{border-left:4px solid var(--accent);color:var(--text-primary)}.toast-info svg{color:var(--accent);flex-shrink:0}.toast-close{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;line-height:1;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .2s}.toast-close:hover{color:var(--text-primary)}@media (max-width:768px){.toast-container{left:1rem;right:1rem}.toast{min-width:auto}}.shortcuts-modal-content{max-width:500px}.shortcuts-grid{display:grid;grid-gap:.75rem;gap:.75rem}.shortcut-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--bg-primary);border-radius:6px}.shortcut-label{font-size:.875rem;color:var(--text-primary)}.shortcut-keys{display:flex;gap:.375rem}.shortcut-key{background:var(--bg-tertiary);color:var(--text-primary);padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;font-family:monospace;border:1px solid var(--border)}.days-since-badge{font-size:.75rem;color:var(--text-secondary);background:var(--bg-secondary);padding:.125rem .5rem;border-radius:12px;font-weight:500}.days-since-badge.warning{background:rgba(255,149,0,.1);color:#ff9500}.days-since-badge.danger{background:rgba(255,69,58,.1);color:var(--danger)}.interaction-count{font-size:.75rem;color:var(--text-secondary);font-weight:500}@keyframes fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:.5}50%{opacity:.3}}.landing-container{background:var(--bg-primary);color:var(--text-primary);position:fixed;top:0;left:0;right:0;bottom:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.landing-hero{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10rem 2rem 8rem;text-align:center;max-width:1000px;margin:0 auto;position:relative;min-height:100vh;overflow:hidden}.landing-hero:before{content:"";position:absolute;top:-20%;left:50%;transform:translateX(-50%);width:120%;height:120%;background:radial-gradient(ellipse at center,var(--accent),transparent 60%);opacity:.04;pointer-events:none;z-index:0}.landing-badge{display:inline-block;padding:.5rem 1.25rem;background:linear-gradient(135deg,var(--accent),var(--accent-hover));color:#fff;border-radius:100px;font-size:.8125rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:2rem;box-shadow:0 4px 16px rgba(0,122,255,.2);position:relative;z-index:1;animation:fadeInUp .6s ease-out}.landing-title{font-size:4rem;font-weight:700;margin-bottom:1.75rem;line-height:1.1;color:var(--text-primary);letter-spacing:-.025em;position:relative;z-index:1;animation:fadeInUp .6s ease-out .1s both}.landing-title-highlight{background:linear-gradient(135deg,var(--accent),var(--accent-hover));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative}.landing-subtitle{font-size:1.25rem;color:var(--text-secondary);margin-bottom:2.5rem;line-height:1.7;max-width:680px;font-weight:400;position:relative;z-index:1;animation:fadeInUp .6s ease-out .2s both}.landing-ctas{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;position:relative;z-index:1;animation:fadeInUp .6s ease-out .3s both}.landing-cta-primary{padding:1.125rem 2.5rem;font-size:1.0625rem;font-weight:600;min-width:200px;border-radius:12px;box-shadow:0 6px 20px rgba(0,122,255,.2);transition:all .3s cubic-bezier(.4,0,.2,1)}.landing-cta-primary:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 12px 32px rgba(0,122,255,.3)}.landing-cta-secondary{padding:1.125rem 2.5rem;font-size:1.0625rem;font-weight:500;min-width:200px;border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1)}.landing-cta-secondary:hover{background:var(--bg-secondary);transform:translateY(-2px)}.landing-trust{display:flex;gap:2rem;margin-top:3rem;flex-wrap:wrap;justify-content:center;position:relative;z-index:1;animation:fadeInUp .6s ease-out .4s both}.landing-trust-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.landing-trust-icon{width:20px;height:20px;background:var(--accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.landing-features-section{background:var(--bg-secondary);padding:6rem 2rem;border-top:1px solid var(--border)}.landing-section-header{text-align:center;max-width:700px;margin:0 auto 4rem}.landing-section-title{font-size:2.5rem;font-weight:700;margin-bottom:1rem;color:var(--text-primary);letter-spacing:-.02em}.landing-section-subtitle{font-size:1.125rem;color:var(--text-secondary);font-weight:400}.landing-features{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:2rem;gap:2rem;max-width:1100px;margin:0 auto}.landing-feature{background:var(--bg-primary);border:1px solid var(--border);border-radius:20px;padding:3rem 2.5rem;text-align:left;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.landing-feature:before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent-hover));opacity:0;transition:opacity .4s ease}.landing-feature:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(0,0,0,.1);border-color:rgba(0,122,255,.3)}.landing-feature:hover:before{opacity:1}.landing-feature-icon-wrapper{width:64px;height:64px;background:linear-gradient(135deg,var(--accent),var(--accent-hover));border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;box-shadow:0 8px 24px rgba(0,122,255,.2);transition:transform .4s cubic-bezier(.4,0,.2,1)}.landing-feature:hover .landing-feature-icon-wrapper{transform:scale(1.1) rotate(-5deg)}.landing-feature-icon{font-size:2rem;filter:none}.landing-feature-title{font-size:1.375rem;font-weight:600;margin-bottom:1rem;color:var(--text-primary);letter-spacing:-.015em}.landing-feature-description{font-size:1rem;color:var(--text-secondary);line-height:1.7}.landing-footer{padding:3rem 2rem;text-align:center;border-top:1px solid var(--border);color:var(--text-secondary);font-size:.875rem;background:var(--bg-secondary);margin-top:auto}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.landing-badge{font-size:.75rem;padding:.4rem 1rem;margin-bottom:1.5rem}.landing-title{font-size:2.5rem;letter-spacing:-.02em;margin-bottom:1.5rem}.landing-subtitle{font-size:1.0625rem;margin-bottom:2rem}.landing-hero{padding:5rem 1.5rem 4rem;min-height:85vh}.landing-trust{flex-direction:column;gap:1rem;margin-top:2rem}.landing-features-section{padding:4rem 1.5rem}.landing-section-title{font-size:2rem}.landing-section-subtitle{font-size:1rem}.landing-features{grid-template-columns:1fr;gap:1.5rem}.landing-feature{padding:2.5rem 2rem}.landing-feature-icon-wrapper{width:56px;height:56px;border-radius:14px}.landing-feature-icon{font-size:1.75rem}.landing-feature-title{font-size:1.25rem}.landing-ctas{flex-direction:column;width:100%;gap:.75rem}.landing-cta-primary,.landing-cta-secondary{width:100%;max-width:340px}}@media (prefers-color-scheme:dark){.landing-feature{background:var(--bg-primary)}.landing-feature:hover{box-shadow:0 16px 40px rgba(0,0,0,.4)}.landing-features-section{background:var(--bg-secondary)}}.quick-log-container{padding:.75rem 2rem 1rem;background:var(--bg-primary);max-width:48rem;margin:0 auto;width:100%}.quick-log-input-area{position:relative}.quick-log-label{display:none}.quick-log-input-wrapper{display:flex;align-items:center;gap:.5rem;padding:.25rem .25rem .25rem 1rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:14px;transition:border-color .2s,box-shadow .2s;box-shadow:0 2px 12px rgba(0,0,0,.06)}.quick-log-input-wrapper:focus-within{border-color:var(--accent);box-shadow:0 2px 12px rgba(0,0,0,.06),0 0 0 3px var(--accent-light)}.quick-log-icon{font-size:1rem;flex-shrink:0;color:var(--text-tertiary)}.quick-log-input{flex:1 1;border:none;background:transparent;font-size:.9375rem;font-family:inherit;color:var(--text-primary);outline:none;padding:.625rem 0}.quick-log-input::placeholder{color:var(--text-tertiary)}.quick-log-submit{display:flex;align-items:center;justify-content:center;gap:.375rem;padding:.5rem .875rem;height:36px;border:none;border-radius:10px;background:var(--text-primary);color:var(--bg-primary);cursor:pointer;transition:opacity .2s;flex-shrink:0;font-size:.8125rem;font-weight:600;font-family:inherit}.quick-log-submit:hover:not(:disabled){opacity:.85}.quick-log-submit:disabled{opacity:.3;cursor:not-allowed}.quick-log-submit-key{opacity:.5;font-size:.875rem}.quick-log-spinner{width:18px;height:18px;border:2px solid hsla(0,0%,100%,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.quick-log-hint{margin-top:.5rem;font-size:.75rem;color:var(--text-tertiary);text-align:center}.quick-log-hint kbd{display:inline-block;padding:.125rem .375rem;background:var(--bg-tertiary);border-radius:4px;font-family:inherit;font-size:.6875rem}.quick-log-confirm-body{padding:1.5rem}.quick-log-confirm-body .form-group{margin-bottom:1.25rem}.quick-log-confirm-body .form-group:last-of-type{margin-bottom:0}.quick-log-warning{background:var(--warning-light);color:var(--warning-dark);padding:.625rem .75rem;border-radius:6px;font-size:.8125rem;margin-bottom:.75rem}.quick-log-select{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:6px;font-size:1rem;font-family:inherit;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:border-color .2s}.quick-log-select:focus{outline:none;border-color:var(--accent)}.quick-log-new-contact-input{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:6px;font-size:1rem;font-family:inherit;background:var(--bg-primary);color:var(--text-primary);margin-top:.75rem;transition:border-color .2s}.quick-log-new-contact-input:focus{outline:none;border-color:var(--accent)}.quick-log-date-input{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:6px;font-size:1rem;font-family:inherit;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:border-color .2s}.quick-log-date-input:focus{outline:none;border-color:var(--accent)}.quick-log-notes-input{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:6px;font-size:1rem;font-family:inherit;background:var(--bg-primary);color:var(--text-primary);resize:vertical;min-height:80px;transition:border-color .2s}.quick-log-notes-input:focus{outline:none;border-color:var(--accent)}.ql-card{position:absolute;bottom:calc(100% + 8px);left:0;right:0;padding:.75rem .875rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:12px;box-shadow:0 -4px 24px rgba(0,0,0,.1),0 -1px 6px rgba(0,0,0,.06);animation:ql-pop-in .2s ease-out;z-index:10}@keyframes ql-pop-in{0%{transform:translateY(6px);opacity:0}to{transform:translateY(0);opacity:1}}.ql-card-row1{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.ql-card-spacer{flex:1 1}.ql-card-avatar{width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.8125rem;font-weight:600;flex-shrink:0;line-height:1}.ql-card-avatar--warning{background:var(--warning);color:#fff}.ql-card-chip{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .625rem;border:1px solid var(--border);border-radius:999px;background:var(--bg-secondary);font-size:.8125rem;font-family:inherit;color:var(--text-primary);cursor:pointer;transition:border-color .15s,background-color .15s;white-space:nowrap}.ql-card-chip:hover{border-color:var(--accent);background:var(--bg-tertiary)}.ql-card-chip--contact{font-weight:600}.ql-card-chip--warning{color:var(--warning-dark);border-color:var(--warning);background:var(--warning-light,rgba(234,179,8,.08))}.ql-card-chip--warning:hover{background:var(--warning-light,rgba(234,179,8,.14))}.ql-card-chip--date{color:var(--text-secondary);font-size:.75rem}.ql-card-chip-caret{opacity:.4;flex-shrink:0}.ql-card-chip:hover .ql-card-chip-caret{opacity:.8}.ql-card-chip-icon{opacity:.5;flex-shrink:0}.ql-card-chip-remove{opacity:.3;flex-shrink:0;cursor:pointer;margin-left:.125rem}.ql-card-chip:hover .ql-card-chip-remove{opacity:.7}.ql-card-chip-remove:hover{opacity:1!important}.ql-card-chip--company,.ql-card-chip--location{font-size:.75rem;color:var(--text-secondary)}.ql-card-tags{display:flex;align-items:center;gap:.375rem;flex-wrap:wrap;margin-bottom:.5rem}.ql-card-inline-text{font-size:.75rem;padding:.25rem .625rem;max-width:180px;width:auto}.ql-card-inline-date,.ql-card-inline-select,.ql-card-inline-text{font-family:inherit;border:1px solid var(--accent);border-radius:999px;background:var(--bg-primary);color:var(--text-primary);outline:none;box-shadow:0 0 0 2px var(--accent-light)}.ql-card-inline-date,.ql-card-inline-select{font-size:.8125rem;padding:.25rem .5rem;max-width:200px}.ql-card-inline-date{font-size:.75rem;padding:.25rem .625rem}.ql-card-dismiss{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:.25rem;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .15s,background-color .15s}.ql-card-dismiss:hover{color:var(--text-primary);background:var(--bg-tertiary)}.ql-card-new-contact{width:100%;padding:.4375rem .75rem;border:1px solid var(--border);border-radius:8px;font-size:.8125rem;font-family:inherit;background:var(--bg-secondary);color:var(--text-primary);margin-bottom:.5rem;transition:border-color .15s}.ql-card-new-contact:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-light)}.ql-card-notes{width:100%;padding:.4375rem .75rem;border:1px solid var(--border);border-radius:8px;font-size:.8125rem;font-family:inherit;background:var(--bg-secondary);color:var(--text-primary);resize:none;min-height:38px;line-height:1.5;transition:border-color .15s}.ql-card-notes:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-light)}.ql-card-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.5rem}.ql-card-skip{padding:.375rem .875rem;font-size:.8125rem;font-weight:500;font-family:inherit;border-radius:8px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:background-color .15s,border-color .15s;line-height:1.4}.ql-card-skip:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--text-tertiary)}.ql-card-skip:disabled{opacity:.4;cursor:not-allowed}.ql-card-save{padding:.375rem 1rem;font-size:.8125rem;font-weight:500;font-family:inherit;border-radius:8px;border:none;background:var(--accent);color:#fff;cursor:pointer;transition:background-color .15s;line-height:1.4}.ql-card-save:hover:not(:disabled){background:var(--accent-hover)}.ql-card-save:disabled{opacity:.4;cursor:not-allowed}.quick-log-autosaved-banner{position:relative;max-width:48rem;padding:.75rem 1rem;background:var(--bg-primary);border:1px solid #10a37f;border-radius:10px;margin:0 auto .5rem;overflow:hidden;animation:slideInDown .3s ease-out}@keyframes slideInDown{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.quick-log-autosaved-content{display:flex;align-items:center;gap:.625rem;flex:1 1;min-width:0}.quick-log-autosaved-icon{color:#10a37f;flex-shrink:0}.quick-log-autosaved-text{font-size:.875rem;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.quick-log-autosaved-text strong{font-weight:600}.quick-log-autosaved-actions{display:flex;align-items:center;gap:.5rem;position:absolute;right:.75rem;top:50%;transform:translateY(-50%)}.quick-log-autosaved-edit{padding:.25rem .75rem;border:1px solid var(--border);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-size:.8125rem;font-family:inherit;cursor:pointer;transition:background-color .2s,border-color .2s}.quick-log-autosaved-edit:hover{background:var(--bg-tertiary);border-color:var(--accent)}.quick-log-autosaved-dismiss{background:none;border:none;color:var(--text-tertiary);font-size:1.25rem;line-height:1;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:color .2s}.quick-log-autosaved-dismiss:hover{color:var(--text-primary)}.quick-log-autosaved-progress{position:absolute;bottom:0;left:0;right:0;height:3px;background:transparent}.quick-log-autosaved-progress-bar{height:100%;background:#10a37f;transition:width 50ms linear;border-radius:0 0 0 10px}@media (max-width:768px){.quick-log-container{padding:.75rem 1rem;position:fixed;bottom:0;left:0;right:0;z-index:100;background:var(--bg-primary);border-top:1px solid var(--border)}.quick-log-hint{display:none}@media (pointer:coarse){.mobile-fab{display:flex;position:fixed;bottom:5rem;right:1rem;width:56px;height:56px;border-radius:50%;background:var(--accent);color:#fff;border:none;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(0,0,0,.2);z-index:99;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.mobile-fab:active{transform:scale(.92);box-shadow:0 2px 8px rgba(0,0,0,.2)}}}