:root{--bg: #f7f9fc;--surface: #ffffff;--surface-soft: #f3f6fb;--text: #182233;--muted: #69758a;--line: #dbe3ef;--primary: #2563eb;--primary-strong: #1d4ed8;--success: #168a4a;--danger: #d03f3f;--badge-chat: #10b44f;--badge-alert: #ef5b2f;--shadow-soft: 0 10px 28px rgba(22, 36, 63, .08);--shadow-card: 0 16px 34px rgba(29, 53, 87, .08);font-family:Manrope,Avenir Next,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0;min-height:100vh;color:var(--text);background:radial-gradient(circle at 8% 8%,rgba(37,99,235,.13),transparent 30rem),radial-gradient(circle at 90% 80%,rgba(16,180,79,.1),transparent 26rem),var(--bg)}input,textarea,button{font:inherit}input,textarea{border:1px solid var(--line);border-radius:12px;padding:.72rem .92rem;width:100%;color:var(--text);background:#fff;outline:none;transition:border-color .2s ease,box-shadow .2s ease}input:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 4px #2563eb26}button{border:1px solid var(--line);border-radius:12px;background:var(--surface);color:var(--text);padding:.62rem 1rem;font-weight:600;cursor:pointer;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}button:hover{border-color:var(--primary);transform:translateY(-1px)}button:disabled{opacity:.5;cursor:not-allowed;transform:none}.danger-button{background:#fff1f1;color:var(--danger);border-color:#f5c8c8}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:1rem}.auth-card{width:min(430px,100%);background:#ffffffeb;border:1px solid var(--line);border-radius:22px;padding:1.4rem;display:grid;gap:.85rem;box-shadow:var(--shadow-card)}.auth-card h1{margin:0}.app-layout{min-height:100vh;display:grid;grid-template-columns:290px 1fr}.sidebar{padding:1rem;border-right:1px solid var(--line);background:#ffffffd1;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);display:grid;align-content:start;gap:1rem}.brand{text-decoration:none;color:var(--text);font-size:1.2rem;font-weight:800}.profile-mini{display:flex;align-items:center;gap:.7rem;padding:.6rem;background:var(--surface-soft);border:1px solid var(--line);border-radius:16px}.avatar{width:44px;height:44px;border-radius:50%;object-fit:cover}.avatar-fallback{display:grid;place-items:center;background:#e8eef9;border:1px solid #cfdcf2}.username{margin:0;font-weight:700}.email{margin:0;font-size:.84rem;color:var(--muted)}.nav-links{display:grid;gap:.45rem}.nav-links a{color:var(--text);text-decoration:none;border:1px solid transparent;border-radius:12px;padding:.6rem .7rem;position:relative;transition:background .2s ease,border-color .2s ease}.nav-links a.active{background:#edf3ff;border-color:#cdddfd}.nav-item{display:inline-flex;align-items:center;gap:.55rem}.nav-item small{font-size:.9rem}.with-badge{position:relative}.badge{min-width:20px;height:20px;padding:0 6px;border-radius:999px;color:#fff;font-size:.72rem;font-weight:800;line-height:20px;text-align:center;position:absolute;top:6px;right:8px;border:2px solid #fff;box-shadow:0 2px 8px #00000029}.badge-chat{background:var(--badge-chat)}.badge-alert{background:var(--badge-alert)}.main-content{padding:1rem}.page{max-width:980px;margin:0 auto;background:#ffffffe6;border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow-card);padding:1rem}.page-header{display:grid;gap:.2rem;margin-bottom:.9rem}.page h1{margin:0;font-size:clamp(1.35rem,3.2vw,1.9rem)}.muted{margin:0;color:var(--muted)}.row-form{display:grid;grid-template-columns:1fr auto;gap:.65rem}.row-form button{background:linear-gradient(180deg,var(--primary),var(--primary-strong));color:#fff;border-color:transparent}.list{margin:.85rem 0 0;padding:0;list-style:none;display:grid;gap:.6rem}.todo-row,.card-row{border:1px solid var(--line);border-radius:14px;background:#fff;padding:.75rem;display:flex;align-items:center;gap:.55rem;box-shadow:var(--shadow-soft)}.todo-row{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.todo-row:hover{transform:translateY(-1px);border-color:#c4d5ee}.todo-row.completed{background:#f4f8f5;border-color:#cde9d7}.todo-checkbox{width:18px;height:18px;accent-color:var(--success)}.todo-row span{min-width:0;grid-column:2}.todo-actions{display:flex;gap:.45rem;grid-column:1 / -1;justify-content:flex-end;margin-top:.3rem}.inline-form{display:flex;gap:.5rem;width:100%;grid-column:2}.done{text-decoration:line-through;color:var(--muted)}.empty-card,.shared-card{margin-top:.9rem;border:1px dashed #c4d5ee;border-radius:16px;padding:1rem;background:#f8fbff}.empty-card h3,.shared-card h2{margin:0 0 .4rem}.shared-item{border:1px solid var(--line);border-radius:12px;background:#fff;padding:.7rem;display:flex;align-items:center;justify-content:space-between;gap:.6rem}.status-pill{border-radius:999px;padding:.2rem .55rem;font-size:.76rem;font-weight:700;border:1px solid transparent}.status-pill.done{color:#0d7c3f;background:#e7f8ee;border-color:#b9e6cb}.status-pill.pending{color:#91520d;background:#fff4e5;border-color:#f4d7ac}.chat-layout{display:grid;grid-template-columns:320px 1fr;gap:.9rem;min-height:580px}.chat-inbox{display:grid;gap:.55rem}.chat-friends{display:grid;gap:.5rem;align-content:start;max-height:600px;overflow:auto;padding-right:4px}.friend-row{width:100%;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.65rem;text-align:left;background:#fff;border:1px solid var(--line);border-radius:14px;padding:.68rem}.mini-avatar-link{text-decoration:none;display:inline-flex}.requester-link{text-decoration:none;color:var(--text);font-weight:700}.friend-row.active{background:#edf3ff;border-color:#c7d9fc}.friend-avatar{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;font-weight:800;background:#e3ebf8;color:#23487d}.friend-meta{display:grid;gap:.06rem}.friend-meta strong{font-size:.95rem}.friend-meta small{color:var(--muted);font-size:.78rem}.friend-preview{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.friend-side{display:grid;justify-items:end;gap:.35rem}.friend-time{color:var(--muted);font-size:.74rem}.friend-side .badge{position:static;display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;line-height:1;padding:0 7px;border-width:1px}.chat-panel{border:1px solid var(--line);border-radius:16px;background:#fff;box-shadow:var(--shadow-soft);display:grid;grid-template-rows:auto 1fr auto;min-height:580px}.chat-header{padding:.75rem .9rem;border-bottom:1px solid var(--line);font-weight:700;display:flex;align-items:center;gap:.7rem;position:sticky;top:0;z-index:2;background:#fff}.chat-header-user{font-size:.96rem}.chat-header-user-link{text-decoration:none;color:inherit;display:inline-flex;align-items:center;gap:.55rem}.back-link{text-decoration:none;color:var(--primary-strong);font-size:.9rem;font-weight:700}.chat-messages{margin:0;padding:.9rem;list-style:none;display:grid;gap:.55rem;overflow:auto;align-content:start;background:radial-gradient(circle at 90% 10%,rgba(37,99,235,.08),transparent 18rem),#fcfdff}.bubble{max-width:78%;padding:.62rem .7rem;border-radius:14px;border:1px solid var(--line);box-shadow:var(--shadow-soft)}.bubble p{margin:0;word-break:break-word}.bubble small{display:block;margin-top:.34rem;color:var(--muted);font-size:.72rem}.bubble.mine{margin-left:auto;background:linear-gradient(180deg,#e8efff,#dce8ff);border-color:#c4d8ff}.bubble.theirs{margin-right:auto;background:#fff}.chat-input-row{position:sticky;bottom:0;padding:.75rem;background:#fff;border-top:1px solid var(--line);align-items:end}.single-chat-panel{min-height:640px;height:min(75vh,720px);overflow:hidden}.chat-message-input{min-height:92px;resize:vertical}.chat-input-row button{min-height:46px;min-width:90px;font-weight:800}.button-row{margin-left:auto;display:flex;gap:.5rem}.error{color:var(--danger)}.success{color:var(--success)}.dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a152859;display:grid;place-items:center;padding:1rem;z-index:100}.dialog-card{width:min(420px,100%);background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-card);padding:1rem;display:grid;gap:.7rem}.dialog-card h3,.dialog-card p{margin:0}.profile-header-card{display:grid;grid-template-columns:auto 1fr;gap:.9rem;align-items:center;padding:.9rem;border:1px solid var(--line);border-radius:16px;background:#f8fbff}.profile-hero-avatar{width:74px;height:74px;border-radius:50%;object-fit:cover}.profile-action-row{display:flex;gap:.55rem;margin-top:.6rem;align-items:center}.profile-action-row a{color:var(--primary-strong);text-decoration:none}.center-note{display:grid;place-items:center;min-height:100vh}@media (max-width: 900px){.app-layout{grid-template-columns:1fr}.sidebar{position:fixed;left:0;right:0;bottom:0;z-index:30;border-right:0;border-top:1px solid var(--line);padding:.36rem .35rem calc(.36rem + env(safe-area-inset-bottom));display:block;box-shadow:0 -8px 24px #22385e1f}.brand,.profile-mini,.sidebar>.danger-button{display:none}.nav-links{grid-template-columns:repeat(5,minmax(0,1fr));gap:.22rem}.nav-links a{text-align:center;padding:.42rem .2rem}.nav-item{display:grid;justify-items:center;gap:.08rem}.nav-item small{font-size:.67rem}.badge{top:4px;right:9px;min-width:18px;height:18px;line-height:18px;font-size:.66rem}.main-content{padding:.8rem;padding-bottom:calc(90px + env(safe-area-inset-bottom))}.page{padding:.85rem;border-radius:18px}.chat-layout{grid-template-columns:1fr;min-height:auto}.chat-inbox{gap:.5rem}.chat-panel{min-height:460px}.single-chat-panel{min-height:520px;height:min(70vh,620px)}.bubble{max-width:88%}.todo-actions{justify-content:stretch}.todo-actions button{flex:1}.profile-header-card{grid-template-columns:1fr;justify-items:center;text-align:center;gap:.7rem}.profile-header-card h2{margin:0}.profile-header-card .muted{margin-top:.2rem}}
