*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #ffffff;--bg-surface: #fafafa;--bg-elevated: #f5f5f5;--bg-hover: #f0f0f0;--border: #e5e5e5;--border-focus: #000000;--text-primary: #0a0a0a;--text-secondary: #666666;--text-muted: #999999;--accent: #0a0a0a;--accent-light: #333333;--success: #22c55e;--danger: #dc2626;--mono: "JetBrains Mono", "Fira Code", monospace;--sans: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--radius: 8px;--radius-sm: 6px;--radius-lg: 10px;--transition: .15s ease}html,body{height:100%;overflow:hidden}body{font-family:var(--sans);background:var(--bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{height:100%;display:flex;flex-direction:column}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .2s ease-out forwards}.slide-up{animation:slideUp .3s ease-out forwards}.login-view{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100%;padding:2rem;animation:fadeIn .4s ease-out}.login-logo{font-size:2rem;margin-bottom:.25rem;letter-spacing:-1px;font-weight:700;color:var(--text-primary)}.login-tagline{color:var(--text-muted);font-size:.8rem;margin-bottom:3rem;letter-spacing:1px;text-transform:lowercase}.login-actions{display:flex;flex-direction:column;gap:.75rem;width:100%;max-width:340px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.25rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text-primary);font-family:var(--sans);font-size:.85rem;font-weight:500;cursor:pointer;transition:all var(--transition);user-select:none;-webkit-tap-highlight-color:transparent;min-height:44px}.btn:hover{background:var(--bg-hover);border-color:var(--text-muted)}.btn:active{transform:scale(.98)}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-light);border-color:var(--accent-light)}.btn-danger{border-color:#dc26264d;color:var(--danger)}.btn-danger:hover{background:#dc26260d;border-color:var(--danger)}.btn-ghost{background:transparent;border-color:transparent;color:var(--text-secondary);padding:.5rem .75rem;min-height:unset}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-elevated)}.btn-sm{padding:.4rem .75rem;font-size:.78rem;min-height:34px}.input-group{display:flex;flex-direction:column;gap:.375rem}.input-label{font-size:.72rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.input{padding:.75rem .875rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-family:var(--sans);font-size:.85rem;transition:border-color var(--transition);outline:none;min-height:44px}.input:focus{border-color:var(--border-focus)}.input-mono{font-family:var(--mono);font-size:.78rem}textarea.input{resize:vertical;min-height:90px;line-height:1.6}.recover-form{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:340px;animation:slideUp .3s ease-out}.recover-tabs{display:flex;gap:0;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.recover-tab{flex:1;padding:.5rem;background:transparent;border:none;color:var(--text-muted);font-family:var(--sans);font-size:.78rem;font-weight:500;cursor:pointer;transition:all var(--transition)}.recover-tab.active{background:var(--accent);color:#fff}.error-msg{color:var(--danger);font-size:.78rem;padding:.5rem .75rem;background:#dc26260d;border-radius:var(--radius-sm);border:1px solid rgba(220,38,38,.15)}.mnemonic-display{display:grid;grid-template-columns:repeat(3,1fr);gap:.375rem;padding:1rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius)}.mnemonic-word{display:flex;align-items:center;gap:.375rem;padding:.375rem .5rem;background:var(--bg);border-radius:var(--radius-sm);font-family:var(--mono);font-size:.75rem}.mnemonic-word .num{color:var(--text-muted);font-size:.62rem;min-width:14px}.mnemonic-warning{padding:.875rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);font-size:.78rem;color:var(--text-secondary);line-height:1.5}.main-layout{display:flex;flex-direction:column;height:100%}.top-bar{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;border-bottom:1px solid var(--border);background:var(--bg);flex-shrink:0;min-height:52px}.top-bar-title{font-size:1rem;font-weight:600;letter-spacing:-.3px}.top-bar-actions{display:flex;align-items:center;gap:.5rem}.status-dot{width:6px;height:6px;border-radius:50%;background:var(--text-muted);display:inline-block;margin-right:.25rem;transition:background var(--transition)}.status-dot.connected{background:var(--success)}.status-text{font-size:.65rem;color:var(--text-muted);font-family:var(--mono)}.inbox-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.inbox-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:2rem;color:var(--text-muted);text-align:center;gap:.75rem}.inbox-empty-text{font-size:.85rem;line-height:1.6}.msg-item{display:flex;flex-direction:column;gap:.25rem;padding:.875rem 1.25rem;border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--transition);animation:fadeIn .2s ease-out forwards;position:relative}.msg-item-remove{position:absolute;bottom:.5rem;right:.5rem;width:24px;height:24px;border:none;background:none;color:var(--text-muted);font-size:1rem;cursor:pointer;opacity:0;transition:opacity var(--transition),color var(--transition);display:flex;align-items:center;justify-content:center;border-radius:4px}.msg-item:hover .msg-item-remove{opacity:1}.msg-item-remove:hover{color:var(--danger);background:var(--bg-elevated)}.msg-item:hover{background:var(--bg-surface)}.msg-item:active{background:var(--bg-elevated)}.msg-item.unread{background:var(--bg-surface);border-left:3px solid var(--accent)}.msg-item-header{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem}.msg-item-from{font-weight:500;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.msg-item.unread .msg-item-from{font-weight:700}.msg-item.unread .msg-item-preview{color:var(--text-primary);font-weight:500}.msg-item.unread .msg-item-time{color:var(--text-primary);font-weight:600}.unread-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);display:inline-block;flex-shrink:0;margin-left:.25rem}.msg-item-time{font-size:.68rem;color:var(--text-muted);font-family:var(--mono);flex-shrink:0}.msg-item-preview{font-size:.8rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4}.msg-item-key{font-family:var(--mono);font-size:.65rem;color:var(--text-muted)}.thread-view{display:flex;flex-direction:column;height:100%}.thread-header{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.25rem;border-bottom:1px solid var(--border);background:var(--bg);flex-shrink:0;min-height:52px}.thread-header .back-btn{font-size:.85rem;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;transition:color var(--transition);font-family:var(--sans);font-weight:500}.thread-header .back-btn:hover{color:var(--text-primary)}.thread-contact-info{flex:1;min-width:0}.thread-contact-name{font-weight:500;font-size:.9rem}.thread-contact-key{font-family:var(--mono);font-size:.62rem;color:var(--text-muted);cursor:pointer;transition:color var(--transition)}.thread-contact-key:hover{color:var(--text-secondary)}.thread-contact-key.copied{color:var(--success)}.thread-messages{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0}.thread-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:.82rem}.thread-msg{padding:.875rem 1.25rem;border-bottom:1px solid var(--border);animation:fadeIn .2s ease-out}.thread-msg-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:.375rem}.thread-msg-from{font-weight:500;font-size:.82rem}.thread-msg-from.is-me{font-weight:700;color:var(--text-primary)}.thread-msg-time{font-size:.65rem;color:var(--text-muted);font-family:var(--mono)}.thread-msg-body{font-size:.85rem;line-height:1.6;color:var(--text-primary);word-break:break-word}.thread-msg.is-mine{background:var(--bg-surface);border-left:3px solid var(--accent)}.thread-compose{display:flex;align-items:flex-end;gap:.5rem;padding:.75rem 1.25rem;border-top:1px solid var(--border);background:var(--bg);flex-shrink:0}.thread-compose .input{flex:1;min-height:40px;max-height:120px;resize:none;padding:.5rem .875rem}.thread-compose .send-btn{height:40px;padding:0 1rem;border-radius:var(--radius);background:var(--accent);border:none;color:#fff;font-size:.8rem;font-family:var(--sans);font-weight:500;cursor:pointer;transition:all var(--transition);flex-shrink:0}.thread-compose .send-btn:hover{background:var(--accent-light)}.thread-compose .send-btn:active{transform:scale(.97)}.thread-compose .send-btn:disabled{opacity:.3;cursor:not-allowed;transform:none}.modal-overlay{position:fixed;inset:0;background:#ffffffd9;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:1rem;z-index:100;animation:fadeIn .15s ease-out}.modal{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:400px;padding:1.5rem;animation:slideUp .2s ease-out;box-shadow:0 4px 24px #00000014}.modal-title{font-size:1rem;font-weight:600;margin-bottom:1rem}.modal-actions{display:flex;gap:.5rem;margin-top:1rem}.modal-actions .btn{flex:1}.address-book-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.contact-item{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;border-bottom:1px solid var(--border);transition:background var(--transition)}.contact-item:hover{background:var(--bg-surface)}.contact-info{display:flex;flex-direction:column;gap:.125rem;min-width:0;flex:1;cursor:pointer}.contact-name{font-weight:500;font-size:.85rem}.contact-key{font-family:var(--mono);font-size:.65rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.contact-actions{display:flex;gap:.375rem;flex-shrink:0}.settings-section{padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.settings-section-title{font-size:.68rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:.75rem;font-weight:500}.settings-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0}.settings-item+.settings-item{border-top:1px solid var(--border)}.settings-item-label{font-size:.85rem}.settings-item-value{font-family:var(--mono);font-size:.72rem;color:var(--text-secondary);max-width:55%;text-align:right;word-break:break-all}.copy-btn{padding:.2rem .5rem;font-size:.68rem;border-radius:var(--radius-sm);background:var(--bg-surface);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);font-family:var(--mono)}.copy-btn:hover{border-color:var(--accent);color:var(--accent)}.copy-btn.copied{border-color:var(--success);color:var(--success)}.bottom-nav{display:flex;border-top:1px solid var(--border);background:var(--bg);flex-shrink:0}.nav-item{flex:1;display:flex;align-items:center;justify-content:center;padding:.75rem 0;background:none;border:none;color:var(--text-muted);font-family:var(--sans);font-size:.72rem;font-weight:500;cursor:pointer;transition:color var(--transition);-webkit-tap-highlight-color:transparent;min-height:44px;letter-spacing:.3px}.nav-item:hover,.nav-item.active{color:var(--text-primary)}::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}@media(max-width:480px){.mnemonic-display{grid-template-columns:repeat(2,1fr)}.login-logo{font-size:1.75rem}.top-bar,.thread-header{padding:.75rem 1rem}.msg-item,.contact-item,.settings-section{padding-left:1rem;padding-right:1rem}.thread-compose{padding:.625rem 1rem;padding-bottom:max(.625rem,env(safe-area-inset-bottom))}.bottom-nav{padding-bottom:env(safe-area-inset-bottom)}.thread-msg{padding:.75rem 1rem}.msg-item-remove{opacity:.5}}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.text-mono{font-family:var(--mono)}.text-xs{font-size:.72rem}.text-sm{font-size:.78rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.flex-col{display:flex;flex-direction:column}.hidden{display:none!important}.attach-btn{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:1.1rem;padding:.4rem .6rem;cursor:pointer;color:var(--text-secondary);transition:all var(--transition);flex-shrink:0}.attach-btn:hover{border-color:var(--text-primary);color:var(--text-primary)}.attach-btn:disabled{opacity:.4;cursor:wait}.file-status{font-size:.75rem;color:var(--text-muted);padding:.3rem 1rem .5rem;font-family:var(--mono)}.file-card{display:flex;align-items:center;gap:.6rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:.6rem .8rem;margin-top:.3rem}.file-card-icon{font-size:1.5rem;flex-shrink:0}.file-card-info{flex:1;min-width:0}.file-card-name{font-size:.82rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-card-size{font-size:.72rem;color:var(--text-muted);font-family:var(--mono)}.file-download-btn{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.72rem;padding:.35rem .7rem;cursor:pointer;font-family:var(--mono);transition:all var(--transition);flex-shrink:0}.file-download-btn:hover{background:var(--accent-light)}.file-download-btn:disabled{opacity:.6;cursor:wait}.file-download-btn.downloaded{background:var(--success);cursor:default}.file-seeding{font-size:.72rem;color:var(--success);font-family:var(--mono);flex-shrink:0}.file-progress-container{margin-top:.4rem}.file-progress{height:4px;background:var(--bg-elevated);border-radius:2px;overflow:hidden}.file-progress-bar{height:100%;width:0%;background:var(--accent);transition:width .3s ease;border-radius:2px}.file-progress-stats{display:flex;gap:.7rem;margin-top:.25rem;font-size:.68rem;font-family:var(--mono);color:var(--text-muted)}.file-progress-speed{color:var(--success);font-weight:500}.file-progress-folder{font-size:.65rem;color:var(--text-muted);margin-top:.15rem;font-style:italic}.file-cancel-btn{background:none;border:1px solid var(--danger);border-radius:var(--radius-sm);font-size:.85rem;padding:.25rem .45rem;cursor:pointer;color:var(--danger);transition:all var(--transition);flex-shrink:0}.file-cancel-btn:hover{background:var(--danger);color:#fff}.file-seeding-status{font-size:.72rem;color:var(--text-muted);font-family:var(--mono);flex-shrink:0;font-style:italic}.file-seeding-status.active{color:var(--success);font-style:normal}.file-download-btn.no-seeders{background:var(--danger);opacity:.8}.file-checking{font-size:.72rem;color:var(--text-muted);font-family:var(--mono);flex-shrink:0;animation:pulse 1.5s ease-in-out infinite}.file-no-seeders{font-size:.72rem;color:var(--danger);font-family:var(--mono);flex-shrink:0}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}
