*{box-sizing:border-box}:root{--bg:#f0f2f5;--panel:#ffffff;--border:#e4e6eb;--text:#111b21;--muted:#667781;--accent:#25d366;--accent-dark:#128c7e;--in:#ffffff;--out:#d9fdd3;--read:#53bdeb}body,html{margin:0;padding:0;height:100%;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--text);background:var(--bg)}.login-wrap{display:flex;align-items:center;justify-content:center;height:100vh}.login-card{background:var(--panel);padding:2rem;border-radius:12px;box-shadow:0 4px 20px rgba(0,0,0,.08);width:320px;display:flex;flex-direction:column;gap:.75rem}.login-card h1{margin:0;font-size:1.25rem}.login-card label{display:flex;flex-direction:column;gap:.25rem;font-size:.85rem;color:var(--muted)}.login-card input{padding:.6rem;border:1px solid var(--border);border-radius:8px;font-size:.95rem}.login-card button{margin-top:.5rem;padding:.65rem;border:none;border-radius:8px;background:var(--accent-dark);color:#fff;font-weight:600;cursor:pointer}.login-card button:disabled{opacity:.6;cursor:default}.error{color:#c0392b;font-size:.85rem;margin:0}.muted{color:var(--muted)}.inbox{display:grid;grid-template-columns:340px 1fr;height:100vh}.sidebar{background:var(--panel);border-right:1px solid var(--border);display:flex;flex-direction:column;min-height:0}.sidebar-head{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid var(--border)}.link-btn{background:none;border:none;color:var(--accent-dark);cursor:pointer;font-size:.85rem}.main{min-height:0;display:flex}.conv-list{list-style:none;margin:0;padding:0;overflow-y:auto;flex:1 1}.conv-item{width:100%;text-align:left;background:none;border:none;border-bottom:1px solid var(--border);padding:.75rem 1rem;cursor:pointer;display:flex;flex-direction:column;gap:.2rem}.conv-item:hover{background:#f5f6f6}.conv-item.active{background:#e9edef}.conv-top{display:flex;justify-content:space-between;align-items:baseline}.conv-name{font-weight:600}.conv-time{font-size:.75rem;color:var(--muted)}.conv-sub{font-size:.8rem;color:var(--muted);display:flex;align-items:center;gap:.4rem}.dot-open{width:8px;height:8px;border-radius:50%;background:var(--accent);display:inline-block}.thread{display:flex;flex-direction:column;flex:1 1;min-height:0}.thread-head{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem;background:var(--panel);border-bottom:1px solid var(--border)}.thread-title{font-weight:600}.thread-body{flex:1 1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.4rem;background:#efeae2}.pill{font-size:.75rem;padding:.25rem .6rem;border-radius:999px;font-weight:600}.pill-open{background:#d9fdd3;color:var(--accent-dark)}.pill-closed{background:#ffe0e0;color:#c0392b}.bubble-row{display:flex}.bubble-row.in{justify-content:flex-start}.bubble-row.out{justify-content:flex-end}.bubble{max-width:65%;padding:.45rem .6rem;border-radius:8px;background:var(--in);box-shadow:0 1px .5px rgba(0,0,0,.1);font-size:.92rem}.bubble-row.out .bubble{background:var(--out)}.bubble-media{font-size:.8rem;color:var(--muted);margin-bottom:.2rem}.bubble-text{white-space:pre-wrap;word-break:break-word}.bubble-meta{display:flex;justify-content:flex-end;gap:.3rem;font-size:.68rem;color:var(--muted);margin-top:.15rem}.tick.read{color:var(--read)}.empty{flex:1 1;display:flex;align-items:center;justify-content:center;color:var(--muted);width:100%}.empty.small{padding:1rem;font-size:.85rem}.composer-placeholder{padding:.9rem 1rem;color:var(--muted);font-size:.85rem;text-align:center}.composer,.composer-placeholder{background:var(--panel);border-top:1px solid var(--border)}.composer{display:flex;gap:.5rem;align-items:flex-end;padding:.6rem .8rem}.composer.closed{justify-content:center;color:var(--muted);font-size:.85rem;padding:.9rem 1rem}.composer-input{flex:1 1;resize:none;max-height:120px;padding:.6rem .8rem;border:1px solid var(--border);border-radius:20px;font-size:.95rem;font-family:inherit;line-height:1.3}.composer-input:focus{outline:none;border-color:var(--accent-dark)}.composer-send{border:none;background:var(--accent-dark);color:#fff;font-weight:600;padding:.6rem 1.1rem;border-radius:20px;cursor:pointer}.composer-send:disabled{opacity:.5;cursor:default}