*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f0f2f5;color:#222;min-height:100vh}.loading{display:flex;align-items:center;justify-content:center;height:100vh;color:#888}.container{max-width:800px;margin:0 auto;padding:24px 16px}h1{font-size:1.6rem}h2{font-size:1.1rem;margin-bottom:12px;color:#444}.card{background:#fff;border-radius:12px;padding:20px;margin-bottom:20px;box-shadow:0 1px 4px #00000014}textarea{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:.95rem;resize:vertical;margin-bottom:10px;font-family:inherit}button{background:#2563eb;color:#fff;border:none;border-radius:8px;padding:9px 18px;font-size:.9rem;cursor:pointer;transition:background .15s}button:hover{background:#1d4ed8}button:disabled{background:#93c5fd;cursor:not-allowed}.status{margin-top:8px;font-size:.85rem;color:#555}.badge{display:inline-block;background:#e0e7ff;color:#3730a3;border-radius:20px;padding:2px 10px;font-size:.8rem;font-weight:600;margin-left:6px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.btn-logout{background:#f1f5f9;color:#64748b;font-size:.85rem;padding:7px 14px}.btn-logout:hover{background:#e2e8f0}.user-list{display:flex;flex-direction:column;gap:10px}.user-item{display:flex;align-items:center;gap:12px;padding:14px 18px;background:#f8f9fb;border-radius:8px;transition:background .15s;flex-wrap:wrap}.user-item.clickable{cursor:pointer}.user-item.clickable:hover{background:#e8edf5}.username{color:#2563eb;font-size:.9rem}.user-id{color:#888;font-size:.8rem}.date{color:#aaa;font-size:.8rem}.user-stats{display:grid;grid-template-columns:1fr 1fr;gap:0;padding:0;overflow:hidden}.stat-row{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;border-bottom:1px solid #f0f2f5;gap:16px}.stat-row:last-child,.stat-row:nth-last-child(2):nth-child(odd){border-bottom:none}.stat-row:nth-child(odd){border-right:1px solid #f0f2f5}.stat-label{color:#888;font-size:.9rem}.stat-value{font-size:.95rem;font-weight:500}.muted{color:#aaa;font-weight:400}.tg-link{color:#2563eb;text-decoration:none}.tg-link:hover{text-decoration:underline}.tabs{display:flex;gap:4px;margin-bottom:16px;background:#e2e8f0;padding:4px;border-radius:10px}.tab{flex:1;background:transparent;color:#64748b;border:none;border-radius:8px;padding:9px 16px;font-size:.95rem;cursor:pointer;transition:background .15s,color .15s}.tab:hover{background:#cbd5e1;color:#334155}.tab.tab-active{background:#fff;color:#1e293b;font-weight:600;box-shadow:0 1px 3px #0000001a}.tab-hint{font-size:.8rem;font-weight:400;color:#94a3b8}.tab-content{display:flex;flex-direction:column;gap:0}.empty{color:#aaa;font-size:.9rem}.highlight{animation:flash 1.5s ease-out}@keyframes flash{0%{background:#dbeafe}to{background:#f8f9fb}}.dialog-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}.back-link{color:#2563eb;text-decoration:none;font-size:.95rem}.back-link:hover{text-decoration:underline}.messages{background:#fff;border-radius:12px;padding:16px;min-height:300px;max-height:500px;overflow-y:auto;margin-bottom:16px;display:flex;flex-direction:column;gap:8px;box-shadow:0 1px 4px #00000014}.message{display:flex;flex-direction:column;max-width:70%}.message-in{align-self:flex-start}.message-out{align-self:flex-end}.bubble{padding:10px 14px;border-radius:16px;font-size:.95rem;line-height:1.4;word-break:break-word;white-space:pre-wrap}.message-in .bubble{background:#f0f2f5;border-bottom-left-radius:4px}.message-out .bubble{background:#2563eb;color:#fff;border-bottom-right-radius:4px}.msg-time{font-size:.72rem;color:#aaa;margin-top:3px;padding:0 4px}.message-out .msg-time{text-align:right}.send-box{display:flex;flex-direction:column}.send-actions{display:flex;gap:8px;align-items:center;justify-content:flex-end}.btn-attach{background:#f1f5f9;color:#475569;font-size:1.1rem;padding:7px 12px;border-radius:8px}.btn-attach:hover{background:#e2e8f0}.msg-image{max-width:100%;max-height:300px;border-radius:8px;display:block;cursor:pointer}.msg-video{max-width:100%;max-height:220px;width:100%;border-radius:8px;display:block;background:#000}.msg-video-note{width:200px;height:200px;border-radius:50%;display:block;object-fit:cover;background:#000}.msg-file-link{display:inline-block;padding:6px 10px;background:#00000014;border-radius:6px;text-decoration:none;color:inherit;font-size:.9rem;word-break:break-all}.message-out .msg-file-link{background:#fff3}.msg-caption{display:block;margin-top:6px;font-size:.9rem}.audio-player{display:flex;align-items:center;gap:8px;padding:6px 4px;min-width:220px;max-width:280px}.audio-btn{background:none;border:none;font-size:1.1rem;padding:4px;cursor:pointer;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.audio-in .audio-btn:hover{background:#00000014}.audio-out .audio-btn:hover{background:#fff3}.audio-loop{font-size:.85rem;opacity:.4}.audio-loop.active{opacity:1}.audio-track{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.audio-seek{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:3px;border-radius:2px;outline:none;cursor:pointer;background:linear-gradient(to right,currentColor var(--progress, 0%),rgba(128,128,128,.3) var(--progress, 0%))}.audio-in .audio-seek{color:#2563eb}.audio-out .audio-seek{color:#ffffffe6}.audio-seek::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:10px;border-radius:50%;background:currentColor}.audio-time{display:flex;justify-content:space-between;font-size:.7rem;opacity:.6;padding:0 1px}body:has(.login-page){display:flex;align-items:center;justify-content:center}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;width:100%}.login-box{background:#fff;border-radius:16px;padding:40px 36px;width:100%;max-width:360px;box-shadow:0 4px 24px #0000001a}.login-box h1{font-size:1.3rem;margin-bottom:24px;text-align:center}.login-box input{display:block;width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:.95rem;margin-bottom:12px;font-family:inherit}.login-box input:focus{outline:none;border-color:#2563eb}.login-box button{width:100%;padding:11px;font-size:1rem;margin-top:4px}.login-error{color:#dc2626;font-size:.85rem;margin-top:10px;text-align:center}.bank-summary{display:flex;gap:32px;margin-bottom:16px}.bank-stat{display:flex;flex-direction:column;gap:2px}.bank-label{font-size:.8rem;color:#888}.bank-value{font-size:1.5rem;font-weight:700}.bank-value.negative{color:#dc2626}.inline-form{display:flex;gap:8px;align-items:center}.inline-form input{padding:9px 12px;border:1px solid #ddd;border-radius:8px;font-size:.95rem;font-family:inherit;width:180px}.inline-form input:focus{outline:none;border-color:#2563eb}.status.error{color:#dc2626}.add-tx-form{display:flex;gap:8px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.add-tx-form input{padding:9px 12px;border:1px solid #ddd;border-radius:8px;font-size:.95rem;font-family:inherit}.add-tx-form input:focus{outline:none;border-color:#2563eb}.tx-input-amount{width:140px}.tx-input-message{flex:1;min-width:160px}.tx-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}.tx-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:#f8f9fb;border-radius:8px;flex-wrap:wrap}.tx-row.tx-editing{background:#eff6ff}.tx-date{font-size:.8rem;color:#aaa;white-space:nowrap}.tx-message{flex:1;font-size:.95rem;min-width:100px}.tx-amount{font-weight:600;white-space:nowrap}.tx-amount.positive{color:#16a34a}.tx-amount.negative{color:#dc2626}.tx-actions{display:flex;gap:6px;flex-shrink:0}.tx-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-bottom:12px}.tx-header h2{margin-bottom:0}.tx-page-size{display:flex;align-items:center;gap:8px;font-size:.85rem;color:#888}.tx-page-size select{padding:5px 8px;border:1px solid #ddd;border-radius:8px;font-size:.85rem;font-family:inherit;cursor:pointer}.tx-page-size select:focus{outline:none;border-color:#2563eb}.tx-pagination{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:12px}.tx-page-info{font-size:.9rem;color:#555;padding:0 8px}.btn-ghost{background:#e2e8f0;color:#475569;font-size:.85rem;padding:6px 12px}.btn-ghost:hover{background:#cbd5e1}.btn-sm{font-size:.8rem;padding:5px 10px}.dialog-toolbar{display:flex;justify-content:flex-end;margin-bottom:8px}.btn-danger{background:#fee2e2;color:#dc2626;font-size:.85rem;padding:6px 12px}.btn-danger:hover{background:#fecaca}.donations-filter{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.donations-filter label{display:flex;align-items:center;gap:8px;font-size:.9rem;color:#555}.donations-filter input[type=date]{padding:8px 10px;border:1px solid #ddd;border-radius:8px;font-size:.9rem;font-family:inherit;cursor:pointer}.donations-filter input[type=date]:focus{outline:none;border-color:#2563eb}.donations-total{margin-left:auto;font-size:1rem;color:#555}.donations-total strong{color:#dc2626;font-size:1.2rem}.add-note-form{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.add-note-bottom{display:flex;gap:8px;flex-wrap:wrap}.add-note-bottom .note-tags-input{flex:1;min-width:200px}.note-text-input{width:100%;box-sizing:border-box;padding:8px 10px;border:1px solid #cbd5e1;border-radius:6px;font:inherit;resize:vertical}.note-text-input:focus{outline:none;border-color:#2563eb}.note-tags-input{padding:8px 10px;border:1px solid #cbd5e1;border-radius:6px;font:inherit}.note-tags-input:focus{outline:none;border-color:#2563eb}.notes-filter{display:flex;gap:8px;margin:12px 0 8px;flex-wrap:wrap;align-items:center}.note-search-input{flex:1;min-width:180px;padding:6px 10px;border:1px solid #cbd5e1;border-radius:6px;font:inherit}.note-search-input:focus{outline:none;border-color:#2563eb}.notes-tags-cloud{display:flex;flex-wrap:wrap;gap:6px;padding:8px 0;margin-bottom:8px;border-bottom:1px solid #eef2f7}.note-tag-toggle{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border:1px solid #cbd5e1;border-radius:999px;background:#f8fafc;color:#475569;font-size:.85rem;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.note-tag-toggle:hover{background:#eef2f7}.note-tag-toggle.active{background:#2563eb;border-color:#2563eb;color:#fff}.note-tag-count{background:#00000014;border-radius:999px;padding:0 6px;font-size:.75rem;line-height:1.4}.note-tag-toggle.active .note-tag-count{background:#ffffff40}.notes-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}.note-row{display:flex;gap:12px;align-items:flex-start;padding:10px 12px;background:#f8fafc;border:1px solid #eef2f7;border-radius:8px}.note-row.note-editing{background:#eff6ff;flex-direction:column;gap:8px}.note-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.note-text{white-space:pre-wrap;word-break:break-word;font-size:.95rem;color:#1e293b}.note-tags{display:flex;flex-wrap:wrap;gap:4px}.note-tag{display:inline-block;padding:2px 8px;border-radius:999px;background:#e0e7ff;color:#4338ca;font-size:.8rem}.note-meta{display:flex;flex-direction:column;gap:6px;align-items:flex-end;flex-shrink:0}.note-date{font-size:.8rem;color:#94a3b8;white-space:nowrap}.note-attach{font-size:.9rem;cursor:pointer}.note-file-preview{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#eef2f7;border-radius:6px}.note-photo-preview{max-width:120px;max-height:120px;border-radius:6px;object-fit:cover}.note-photo{flex-shrink:0;display:block;width:96px;height:96px;border-radius:8px;overflow:hidden;background:#e2e8f0;align-self:flex-start}.note-photo img{width:100%;height:100%;object-fit:cover;display:block}.note-file-link{display:inline-block;color:#2563eb;text-decoration:none;font-size:.9rem}.note-file-link:hover{text-decoration:underline}.note-files-preview{display:flex;flex-wrap:wrap;gap:8px;padding:6px 0}.note-file-thumb{position:relative;width:88px;height:88px;border-radius:6px;overflow:hidden;background:#eef2f7;display:flex;align-items:center;justify-content:center}.note-file-thumb .note-photo-preview{width:100%;height:100%;object-fit:cover;max-width:none;max-height:none;border-radius:0}.note-file-thumb-label{font-size:.75rem;color:#475569;padding:4px;text-align:center;word-break:break-word;line-height:1.2}.note-file-thumb-remove{position:absolute;top:2px;right:2px;width:22px;height:22px;border-radius:50%;border:none;background:#0000008c;color:#fff;font-size:14px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.note-file-thumb-remove:hover{background:#000c}.note-gallery{flex-shrink:0;align-self:flex-start;display:flex;gap:4px}.note-gallery .note-photo{width:96px;height:96px;border-radius:8px;overflow:hidden;background:#e2e8f0;display:block}.note-gallery.note-gallery-multi{display:grid;grid-template-columns:repeat(auto-fit,64px);gap:4px;max-width:208px}.note-gallery.note-gallery-multi .note-photo{width:64px;height:64px;border-radius:6px}.note-gallery .note-photo img{width:100%;height:100%;object-fit:cover;display:block}.login-divider{display:flex;align-items:center;gap:10px;color:#94a3b8;font-size:.85rem;margin:16px 0 12px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#e2e8f0}.login-tg{display:flex;flex-direction:column;align-items:center;gap:8px}.login-tg-widget{display:flex;justify-content:center;min-height:40px}.login-tg .muted{font-size:.85rem;color:#94a3b8}.perms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.perms-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f8fafc;border:1px solid #eef2f7;border-radius:8px;font-size:.95rem;cursor:pointer;-webkit-user-select:none;user-select:none}.perms-item input{accent-color:#2563eb;width:16px;height:16px}
