@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#07101e;--surface:#0d1b2e;--surface-2:#112035;--surface-3:#162540;--border:#1e3450;--border-soft:#38bdf812;--text:#def;--text-2:#9dbdd8;--text-muted:#4d7599;--accent:#38bdf8;--accent-2:#0ea5e9;--accent-3:#0284c7;--accent-glow:#38bdf847;--accent-soft:#38bdf814;--accent-mid:#38bdf829;--gradient:linear-gradient(135deg, #38bdf8 0%, #0ea5e9 60%, #6366f1 100%);--gradient-2:linear-gradient(135deg, #1e3a5f 0%, #0f2744 100%);--gradient-cover:linear-gradient(135deg, #0c2340 0%, #0a3d6b 40%, #0e4d8a 70%, #1a6aaf 100%);--danger:#f87171;--danger-soft:#f871711a;--online:#34d399;--radius-xs:6px;--radius-sm:10px;--radius:14px;--radius-lg:20px;--radius-xl:28px;--shadow-xs:0 1px 3px #0006;--shadow-sm:0 2px 10px #00000080, 0 0 0 1px #38bdf80a;--shadow:0 4px 20px #0000008c, 0 0 0 1px #38bdf80f;--shadow-lg:0 12px 48px #000000b3, 0 0 0 1px #38bdf814;--shadow-accent:0 6px 24px #38bdf84d;--glow-sm:0 0 16px #38bdf826;--glow:0 0 32px #38bdf833;--topbar-bg:#0d1b2eeb;--sidebar-w:260px;--topbar-h:62px;--font:"Bricolage Grotesque", "Dangrek", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--t:.18s;--ease:cubic-bezier(.4, 0, .2, 1)}:root[data-theme=light]{--topbar-bg:#ffffffe0;--bg:#f0f4f8;--surface:#fff;--surface-2:#f5f8fb;--surface-3:#eaeff5;--border:#cddbe9;--border-soft:#0ea5e91f;--text:#0f2333;--text-2:#3a5a73;--text-muted:#7a9ab5;--accent:#0ea5e9;--accent-2:#0284c7;--accent-3:#0369a1;--accent-glow:#0ea5e933;--accent-soft:#0ea5e914;--accent-mid:#0ea5e924;--gradient:linear-gradient(135deg, #38bdf8 0%, #0ea5e9 60%, #6366f1 100%);--gradient-2:linear-gradient(135deg, #dbeafe 0%, #e0f2fe 100%);--gradient-cover:linear-gradient(135deg, #bfdbfe 0%, #7dd3fc 40%, #38bdf8 70%, #0ea5e9 100%);--danger:#ef4444;--danger-soft:#ef444414;--online:#22c55e;--shadow-xs:0 1px 3px #00000012;--shadow-sm:0 2px 10px #00000014;--shadow:0 4px 20px #00000017;--shadow-lg:0 12px 48px #0000001f;--shadow-accent:0 6px 24px #0ea5e933;--glow-sm:0 0 16px #0ea5e91a;--glow:0 0 32px #0ea5e91f}html,body{height:100%;overflow:hidden}html{scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;transition:background .25s var(--ease), color .25s var(--ease);font-size:15px;line-height:1.55}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,textarea{font-family:inherit;font-size:15px}img{display:block}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--accent-3)}.app-layout{flex-direction:column;height:100vh;display:flex;overflow:hidden}.main-content{margin-top:calc(var(--topbar-h) + env(safe-area-inset-top,0px));flex-direction:column;flex:1;align-items:center;width:100%;min-width:0;padding:28px 24px;display:flex;overflow:hidden auto}.main-content--messages{height:calc(100dvh - var(--topbar-h) - env(safe-area-inset-top,0px));align-items:stretch;padding:0;overflow:hidden}@media (width<=768px){input,textarea,select{font-size:16px!important}.main-content{padding:12px 12px calc(64px + env(safe-area-inset-bottom))}.topbar{padding:env(safe-area-inset-top,0px) 12px 0;gap:8px}.topbar-nav{gap:0}.topbar-link{padding:8px 10px}.topbar-right{gap:6px}.topbar-new-post{padding:7px 10px}.topbar-sign-in{padding:6px 10px;font-size:13px}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes popIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}@keyframes shimmer{0%,to{opacity:.7}50%{opacity:1}}.loading-screen{height:100vh;color:var(--text-muted);letter-spacing:.3px;flex-direction:column;justify-content:center;align-items:center;gap:18px;font-size:14px;font-weight:500;display:flex}.loading-screen:before{content:"";border:2px solid var(--border);border-top-color:var(--accent);width:40px;height:40px;box-shadow:var(--glow-sm);border-radius:50%;animation:.75s linear infinite spin}.loading-spinner{color:var(--text-muted);justify-content:center;align-items:center;gap:10px;padding:48px;font-size:13.5px;display:flex}.loading-spinner:before{content:"";border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.75s linear infinite spin}.topbar{height:calc(var(--topbar-h) + env(safe-area-inset-top,0px));padding:env(safe-area-inset-top,0px) 20px 0;background:var(--topbar-bg);border-bottom:1px solid var(--border);transition:background .25s var(--ease);-webkit-backdrop-filter:blur(20px);z-index:200;align-items:center;gap:16px;display:flex;position:fixed;top:0;left:0;right:0}.topbar-logo{flex-shrink:0;align-items:center;gap:9px;text-decoration:none;display:flex}.sidebar-logo-icon{border-radius:var(--radius-sm);background:var(--gradient);color:#fff;width:34px;height:34px;box-shadow:var(--shadow-accent);flex-shrink:0;justify-content:center;align-items:center;font-size:17px;font-weight:800;display:flex}.topbar-logo span{letter-spacing:-.4px;background:var(--gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:18px;font-weight:800}.topbar-logo-img{object-fit:cover;border:2px solid var(--accent-mid);width:36px;height:36px;box-shadow:0 0 10px var(--accent-glow);border-radius:50%;flex-shrink:0}.topbar-nav{flex:1;justify-content:center;align-items:center;gap:2px;display:flex}.topbar-link{border-radius:var(--radius-sm);color:var(--text-2);transition:background var(--t) var(--ease), color var(--t) var(--ease);white-space:nowrap;align-items:center;gap:7px;padding:8px 14px;font-size:14px;font-weight:500;display:flex;position:relative}.topbar-link:hover{background:var(--accent-soft);color:var(--accent)}.topbar-link.active{background:var(--accent-soft);color:var(--accent);font-weight:700}.topbar-link.active:after{content:"";background:var(--accent);width:60%;height:2px;box-shadow:0 0 10px var(--accent-glow);border-radius:2px 2px 0 0;position:absolute;bottom:-1px;left:20%}@media (width<=600px){.topbar-link-label{display:none}}.sidebar-link-icon-wrap{flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative;overflow:visible}.sidebar-badge{background:var(--danger);color:#fff;min-width:18px;height:18px;animation:popIn .2s var(--ease) both;z-index:10;border-radius:999px;justify-content:center;align-items:center;padding:0 5px;font-size:10px;font-weight:800;line-height:1;display:flex;position:absolute;top:-8px;right:-10px;box-shadow:0 0 10px #f8717199}.topbar-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.topbar-new-post{border-radius:var(--radius-sm);background:var(--gradient);color:#fff;box-shadow:var(--shadow-accent);transition:opacity var(--t), transform var(--t);white-space:nowrap;align-items:center;gap:6px;padding:7px 14px;font-size:13.5px;font-weight:700;display:flex}.topbar-new-post:hover{opacity:.88;transform:translateY(-1px)}@media (width<=500px){.topbar-new-post span{display:none}.topbar-sign-in{padding:6px 8px;font-size:12px}}.topbar-user{border-radius:var(--radius-sm);transition:background var(--t);align-items:center;gap:7px;padding:4px 8px;text-decoration:none;display:flex}.topbar-user:hover{background:var(--surface-3)}.topbar-username{color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:120px;font-size:13px;font-weight:600;overflow:hidden}@media (width<=640px){.topbar-username{display:none}}.sidebar-user-avatar{object-fit:cover;border:2px solid var(--accent-mid);border-radius:50%;flex-shrink:0;width:32px;height:32px}.sidebar-user-menu{width:30px;height:30px;color:var(--text-muted);transition:background var(--t), color var(--t);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-user-menu:hover{background:var(--danger-soft);color:var(--danger)}.navbar{background:var(--topbar-bg);border-top:1px solid var(--border);padding:8px 8px calc(8px + env(safe-area-inset-bottom));z-index:200;-webkit-backdrop-filter:blur(20px);justify-content:space-around;display:none;position:fixed;bottom:0;left:0;right:0}@media (width<=768px){.navbar{display:flex}}.navbar-logo{background:var(--gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:18px;font-weight:800}.navbar-links{gap:2px;display:flex}.navbar-link{border-radius:var(--radius-sm);color:var(--text-muted);transition:color var(--t), background var(--t);flex-direction:column;align-items:center;gap:2px;padding:6px 14px;font-size:10px;font-weight:500;display:flex}.navbar-link>span:first-child{font-size:19px}.navbar-link:hover,.navbar-link.active{color:var(--accent);background:var(--accent-soft)}.navbar-avatar{object-fit:cover;border-radius:50%;width:22px;height:22px}.navbar-logout{color:var(--text-muted);border-radius:var(--radius-sm);padding:6px 10px;font-size:13px}.auth-page{background:var(--bg);place-items:center;min-height:100vh;padding:24px 16px;display:grid;position:relative;overflow:hidden}.auth-page:before{content:"";pointer-events:none;background:radial-gradient(circle,#38bdf812 0%,#0000 65%);width:700px;height:700px;position:fixed;top:-20%;left:-10%}.auth-page:after{content:"";pointer-events:none;background:radial-gradient(circle,#6366f10f 0%,#0000 65%);width:600px;height:600px;position:fixed;bottom:-25%;right:-5%}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:420px;box-shadow:var(--shadow-lg), var(--glow-sm);z-index:1;animation:slideUp .4s var(--ease) both;padding:48px 44px;position:relative}.auth-logo{border-radius:var(--radius-xl) var(--radius-xl) 0 0;height:200px;margin:-48px -44px 24px;overflow:hidden}.auth-logo-img{object-fit:cover;object-position:center;width:100%;height:100%;display:block}.auth-title{letter-spacing:-.7px;background:var(--gradient);-webkit-text-fill-color:transparent;text-align:center;filter:drop-shadow(0 0 20px var(--accent-glow));-webkit-background-clip:text;background-clip:text;margin-bottom:4px;font-size:30px;font-weight:800}.auth-error{background:var(--danger-soft);color:var(--danger);border-radius:var(--radius-sm);border:1px solid #f8717133;margin-bottom:16px;padding:11px 14px;font-size:13.5px;font-weight:500}.auth-form{flex-direction:column;gap:13px;margin-top:30px;display:flex}.auth-form input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);color:var(--text);transition:border-color var(--t), box-shadow var(--t);outline:none;padding:13px 16px;font-size:15px}.auth-form input::placeholder{color:var(--text-muted)}.auth-form input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft), var(--glow-sm)}.auth-form button[type=submit]{background:var(--gradient);color:#fff;border-radius:var(--radius-sm);box-shadow:var(--shadow-accent);letter-spacing:.2px;transition:opacity var(--t), transform var(--t), box-shadow var(--t);margin-top:6px;padding:14px;font-size:15px;font-weight:700}.auth-form button[type=submit]:hover:not(:disabled){opacity:.9;box-shadow:0 10px 32px var(--accent-glow);transform:translateY(-1px)}.auth-form button[type=submit]:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.auth-link{text-align:center;color:var(--text-muted);margin-top:22px;font-size:14px}.auth-link a{color:var(--accent);font-weight:600}.auth-link a:hover{text-decoration:underline}.auth-hint{color:var(--text-muted);text-align:center;font-size:12px;line-height:1.5}.auth-hint strong{color:var(--accent)}.auth-hint a{color:#2aabee;text-decoration:none}.auth-hint a:hover{text-decoration:underline}.auth-forgot{text-align:right;margin-top:-4px}.auth-forgot a{color:var(--accent);font-size:13px;font-weight:500}.auth-forgot a:hover{text-decoration:underline}.guest-banner{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;padding:18px 20px;display:flex}.guest-banner p{color:var(--text-muted);flex:1;min-width:160px;margin:0;font-size:14px}.guest-banner-actions{flex-shrink:0;gap:8px;display:flex}.guest-banner-signin{border-radius:var(--radius-sm);border:1px solid var(--accent);color:var(--accent);white-space:nowrap;transition:background var(--t), color var(--t);padding:8px 16px;font-size:13.5px;font-weight:700}.guest-banner-signin:hover{background:var(--accent);color:#fff}.guest-banner-register{border-radius:var(--radius-sm);background:var(--gradient);color:#fff;white-space:nowrap;box-shadow:var(--shadow-accent);transition:opacity var(--t);padding:8px 16px;font-size:13.5px;font-weight:700}.guest-banner-register:hover{opacity:.88}@media (width<=480px){.guest-banner{flex-direction:column;align-items:flex-start;gap:10px;padding:14px 16px}.guest-banner p{font-size:13px}.guest-banner-actions{width:100%}.guest-banner-signin,.guest-banner-register{text-align:center;flex:1;padding:8px 12px;font-size:13px}}.auth-divider{color:var(--text-muted);align-items:center;gap:12px;margin:16px 0 0;font-size:12px;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-guest-btn{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-muted);cursor:pointer;transition:border-color var(--t), color var(--t);background:0 0;padding:12px;font-size:14px;font-weight:500}.auth-guest-btn:hover{border-color:var(--accent);color:var(--accent)}.comment-guest-prompt{color:var(--text-muted);border-bottom:1px solid var(--border);padding:12px 14px;font-size:13.5px}.comment-guest-prompt a{color:var(--accent);font-weight:600}.comment-guest-prompt a:hover{text-decoration:underline}.topbar-sign-in{border-radius:var(--radius-sm);border:1px solid var(--accent);color:var(--accent);white-space:nowrap;transition:background var(--t), color var(--t);padding:7px 14px;font-size:13.5px;font-weight:700}.topbar-sign-in:hover{background:var(--accent);color:#fff}.post-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:border-color var(--t), box-shadow var(--t);margin-bottom:12px;padding:10px 14px}.post-form:focus-within{box-shadow:var(--shadow), var(--glow-sm);border-color:#38bdf84d}.post-form-inner{align-items:center;gap:10px;display:flex}.post-form-avatar{object-fit:cover;border:2px solid var(--accent-mid);border-radius:50%;flex-shrink:0;width:32px;height:32px}.post-form-body{flex:1}.post-form-textarea{width:100%;color:var(--text);resize:none;min-height:unset;background:0 0;border:none;outline:none;height:auto;padding:0;font-size:14px;line-height:1.5;overflow:hidden}.post-form-textarea::placeholder{color:var(--text-muted)}.post-form-previews{flex-wrap:wrap;gap:8px;display:flex}.preview-wrap{border-radius:var(--radius-sm);position:relative;overflow:hidden}.preview-wrap img{object-fit:cover;width:80px;height:80px}.preview-wrap button{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);width:22px;height:22px;transition:background var(--t);background:#07101ebf;border-radius:50%;justify-content:center;align-items:center;font-size:12px;display:flex;position:absolute;top:4px;right:4px}.preview-wrap button:hover{background:var(--danger)}.post-form-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.image-upload-btn{cursor:pointer;color:var(--text-muted);width:34px;height:34px;transition:background var(--t), color var(--t);border-radius:50%;justify-content:center;align-items:center;font-size:18px;display:flex}.image-upload-btn:hover{background:var(--accent-soft);color:var(--accent)}.char-count{color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:12.5px}.char-count.warn{color:var(--danger);font-weight:600}.post-submit-btn{background:var(--gradient);color:#fff;box-shadow:var(--shadow-accent);transition:opacity var(--t), transform var(--t);border-radius:999px;padding:9px 22px;font-size:14px;font-weight:700}.post-submit-btn:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.post-submit-btn:disabled{opacity:.35;cursor:not-allowed;box-shadow:none}.new-post-page{width:100%;max-width:860px;margin:0 auto;padding:24px 16px}.new-post-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.new-post-header{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:16px 20px;display:flex}.new-post-back{width:36px;height:36px;color:var(--text-2);transition:background var(--t), color var(--t);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.new-post-back:hover{background:var(--surface-2);color:var(--text)}.new-post-title{letter-spacing:-.2px;flex:1;font-size:17px;font-weight:700}.new-post-compose{gap:14px;padding:20px 20px 12px;display:flex}.new-post-avatar{object-fit:cover;border:2px solid var(--accent-mid);border-radius:50%;flex-shrink:0;width:46px;height:46px}.new-post-body{flex-direction:column;flex:1;gap:12px;min-width:0;display:flex}.new-post-user-info{align-items:center;gap:8px;display:flex}.new-post-username{color:var(--text);font-size:15px;font-weight:700}.new-post-textarea{width:100%;min-height:150px;color:var(--text);resize:none;background:0 0;border:none;outline:none;padding:0;font-family:inherit;font-size:17px;line-height:1.65}.new-post-textarea::placeholder{color:var(--text-muted)}.new-post-previews{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px;display:grid}.new-preview-wrap{border-radius:var(--radius-sm);aspect-ratio:1;position:relative;overflow:hidden}.new-preview-wrap img{object-fit:cover;width:100%;height:100%;display:block}.new-preview-remove{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);width:26px;height:26px;transition:background var(--t);background:#07101ec7;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:6px;right:6px}.new-preview-remove:hover{background:var(--danger)}.new-post-options{border-top:1px solid var(--border-soft);flex-wrap:wrap;gap:16px;padding:10px 20px 12px 80px;display:flex}.new-post-option-group{color:var(--text-muted);align-items:center;gap:6px;font-size:13px;display:flex}.new-post-select{color:var(--accent);cursor:pointer;background:0 0;border:none;outline:none;font-family:inherit;font-size:13px;font-weight:600}.new-post-select option{background:var(--surface-2);color:var(--text)}.new-post-location{color:var(--accent);background:0 0;border:none;outline:none;width:150px;font-family:inherit;font-size:13px;font-weight:600}.new-post-location::placeholder{color:var(--text-muted);font-weight:400}.new-post-footer{border-top:1px solid var(--border);align-items:center;gap:8px;padding:12px 20px;display:flex}.image-upload-btn.active{background:var(--accent-soft);color:var(--accent)}.emoji-picker-wrap{position:relative}.emoji-picker{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);width:320px;box-shadow:var(--shadow), 0 0 24px #0006;z-index:100;position:absolute;bottom:calc(100% + 10px);left:0;overflow:hidden}.emoji-tabs{border-bottom:1px solid var(--border);background:var(--surface-3);display:flex}.emoji-tab{text-align:center;cursor:pointer;opacity:.5;transition:opacity var(--t), background var(--t);border-radius:0;flex:1;padding:8px 4px;font-size:18px}.emoji-tab:hover{opacity:.85;background:var(--surface-2)}.emoji-tab.active{opacity:1;background:var(--accent-soft)}.emoji-grid{grid-template-columns:repeat(8,1fr);gap:2px;max-height:200px;padding:8px;display:grid;overflow-y:auto}.emoji-grid::-webkit-scrollbar{width:4px}.emoji-grid::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.emoji-item{border-radius:var(--radius-xs);text-align:center;cursor:pointer;transition:background var(--t), transform var(--t);padding:5px;font-size:20px;line-height:1}.emoji-item:hover{background:var(--accent-soft);transform:scale(1.2)}.post-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-xs);transition:border-color var(--t), box-shadow var(--t);min-width:0;margin-bottom:12px;padding:20px;overflow:hidden}.post-card:hover{box-shadow:var(--shadow-sm), var(--glow-sm);border-color:#38bdf833}.post-header{justify-content:space-between;align-items:flex-start;margin-bottom:13px;display:flex}.post-author{align-items:center;gap:11px;display:flex}.post-avatar{object-fit:cover;border:2px solid var(--border);width:44px;height:44px;transition:border-color var(--t);border-radius:50%;flex-shrink:0}.post-author:hover .post-avatar{border-color:var(--accent);box-shadow:0 0 12px var(--accent-glow)}.post-author-name{color:var(--text);transition:color var(--t);font-size:15px;font-weight:700;display:block}.post-author:hover .post-author-name{color:var(--accent)}.post-author-handle{color:var(--text-muted);margin-top:1px;font-size:13px;display:block}.post-meta{align-items:center;gap:8px;display:flex}.post-time{color:var(--text-muted);font-size:12px}.post-owner-actions{align-items:center;gap:4px;display:flex}.post-icon-btn{width:28px;height:28px;color:var(--text-muted);transition:background var(--t), color var(--t), transform var(--t);border-radius:50%;justify-content:center;align-items:center;display:flex}.post-icon-btn:hover{transform:scale(1.1)}.post-icon-btn.edit-btn:hover{color:#6366f1;background:#6366f11f}.post-icon-btn.delete-btn:hover{background:var(--danger-soft);color:var(--danger)}.post-icon-btn:disabled{opacity:.4;pointer-events:none}.post-edit-form{flex-direction:column;gap:8px;margin-bottom:14px;display:flex}.post-edit-input{background:var(--surface-2);border:1px solid var(--accent);border-radius:var(--radius-sm);width:100%;color:var(--text);resize:vertical;box-shadow:0 0 0 3px var(--accent-soft);outline:none;padding:10px 14px;font-size:15px;line-height:1.65}.post-edit-actions{justify-content:flex-end;gap:8px;display:flex}.post-edit-cancel{color:var(--text-muted);border-radius:var(--radius-xs);border:1px solid var(--border);transition:all var(--t);align-items:center;gap:4px;padding:5px 12px;font-size:13px;font-weight:500;display:flex}.post-edit-cancel:hover{color:var(--text);border-color:var(--text-muted)}.post-edit-save{color:#fff;border-radius:var(--radius-xs);background:var(--gradient);transition:opacity var(--t);align-items:center;gap:4px;padding:5px 14px;font-size:13px;font-weight:600;display:flex}.post-edit-save:disabled{opacity:.4;cursor:not-allowed}.post-edit-images-preview{flex-wrap:wrap;gap:8px;display:flex}.post-edit-image-wrap{border-radius:var(--radius-xs);flex-shrink:0;width:80px;height:80px;position:relative;overflow:hidden}.post-edit-image-thumb{object-fit:cover;width:100%;height:100%}.post-edit-image-remove{color:#fff;cursor:pointer;background:#000000a6;border:none;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;padding:0;display:flex;position:absolute;top:3px;right:3px}.post-edit-toolbar{align-items:center;gap:8px;display:flex}.post-edit-add-img-btn{color:var(--text-muted);border-radius:var(--radius-xs);border:1px solid var(--border);cursor:pointer;transition:all var(--t);align-items:center;gap:4px;padding:5px 10px;font-size:13px;font-weight:500;display:flex}.post-edit-add-img-btn:hover{color:var(--accent);border-color:var(--accent)}.post-edit-visibility-select{color:var(--text-muted);border-radius:var(--radius-xs);border:1px solid var(--border);background:var(--surface-2);cursor:pointer;transition:border-color var(--t);outline:none;padding:5px 10px;font-size:13px;font-weight:500}.post-edit-visibility-select:hover,.post-edit-visibility-select:focus{border-color:var(--accent);color:var(--text)}.post-content{color:var(--text-2);white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word;margin-bottom:14px;font-size:15px;line-height:1.65}.post-images{border-radius:var(--radius-sm);border:1px solid var(--border);gap:3px;margin-bottom:14px;display:grid;overflow:hidden}.post-images.count-1{grid-template-columns:1fr}.post-images.count-2,.post-images.count-3{grid-template-columns:1fr 1fr}.post-images.count-3 .post-image:first-child{grid-column:span 2}.post-image{aspect-ratio:16/9;object-fit:cover;cursor:zoom-in;width:100%;transition:opacity var(--t)}.post-image:hover{opacity:.9}.lightbox-backdrop{z-index:1000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000000eb;justify-content:center;align-items:center;animation:.18s fadeIn;display:flex;position:fixed;inset:0}.lightbox-img{object-fit:contain;border-radius:var(--radius-sm);max-width:90vw;max-height:88vh;animation:.18s zoomIn;box-shadow:0 8px 60px #000000b3}@keyframes zoomIn{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}.lightbox-close{color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);width:42px;height:42px;transition:background var(--t);z-index:1001;background:#ffffff1a;border-radius:50%;justify-content:center;align-items:center;display:flex;position:fixed;top:18px;right:22px}.lightbox-close:hover{background:#ffffff38}.lightbox-nav{color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);width:50px;height:50px;transition:background var(--t);z-index:1001;background:#ffffff1a;border-radius:50%;justify-content:center;align-items:center;display:flex;position:fixed;top:50%;transform:translateY(-50%)}.lightbox-nav:hover{background:#ffffff38}.lightbox-prev{left:18px}.lightbox-next{right:18px}.lightbox-dots{z-index:1001;gap:8px;display:flex;position:fixed;bottom:22px;left:50%;transform:translate(-50%)}.lightbox-dot{width:8px;height:8px;transition:background var(--t), transform var(--t);background:#ffffff59;border-radius:50%}.lightbox-dot.active{background:#fff;transform:scale(1.25)}.post-actions{border-top:1px solid var(--border);gap:2px;padding-top:10px;display:flex}.action-btn{color:var(--text-muted);transition:background var(--t), color var(--t);border-radius:999px;align-items:center;gap:6px;padding:7px 14px;font-size:14px;font-weight:500;display:flex}.action-btn:hover{background:var(--accent-soft);color:var(--accent)}.like-btn:hover{color:#f87171;background:#f871711a}.like-btn.liked{color:#f87171;font-weight:600}.like-btn.liked:hover{background:#f871711f}.comment-section{border-top:1px solid var(--border);animation:fadeIn .2s var(--ease) both;margin-top:14px;padding-top:14px}.comment-form{align-items:center;gap:10px;min-width:0;margin-bottom:14px;display:flex}.comment-avatar{object-fit:cover;border:1px solid var(--border);border-radius:50%;flex-shrink:0;width:32px;height:32px}.comment-input{border:1px solid var(--border);background:var(--surface-2);min-width:0;color:var(--text);transition:border-color var(--t), box-shadow var(--t);border-radius:999px;outline:none;flex:1 1 0;padding:9px 16px;font-size:14px}.comment-input::placeholder{color:var(--text-muted)}.comment-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.comment-submit{background:var(--gradient);color:#fff;transition:opacity var(--t), transform var(--t);white-space:nowrap;border-radius:999px;padding:9px 18px;font-size:13.5px;font-weight:600}.comment-submit:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.comment-submit:disabled{opacity:.35;cursor:not-allowed}.comments-list{flex-direction:column;gap:10px;display:flex}.comment-item{gap:10px;min-width:0;display:flex}.comment-body{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);overflow-wrap:anywhere;word-break:break-word;flex:auto;min-width:0;padding:10px 14px}.comment-author-row{align-items:center;gap:6px;margin-bottom:3px;display:flex}.comment-time{color:var(--text-muted);flex-shrink:0;font-size:11px}.comment-author{color:var(--accent);font-size:13px;font-weight:700}.comment-author:hover{opacity:.8}.comment-text{color:var(--text-2);overflow-wrap:anywhere;word-break:break-word;font-size:14px;line-height:1.5}.comment-actions{justify-content:flex-end;gap:8px;margin-top:6px;display:flex}.comment-action-btn{color:#6366f1;border-radius:var(--radius-xs);transition:background var(--t), color var(--t);background:0 0;padding:2px 6px;font-size:12px;font-weight:600}.comment-action-btn:hover{color:#818cf8;background:#6366f11f}.comment-view-replies-btn{color:var(--text-muted);cursor:pointer;transition:color var(--t);background:0 0;border:none;align-items:center;gap:4px;padding:2px 0;font-size:12px;font-weight:600;display:flex}.comment-view-replies-btn:before{content:"";vertical-align:middle;background:currentColor;width:16px;height:1px;display:inline-block}.comment-view-replies-btn:hover{color:var(--text-primary)}.reply-form{align-items:center;gap:8px;min-width:0;margin-top:8px;display:flex}.reply-avatar{width:26px;height:26px}.replies-list{border-left:2px solid var(--border);flex-direction:column;gap:8px;min-width:0;margin-top:8px;padding-left:12px;display:flex}.reply-item .comment-body{background:var(--surface-3)}.feed-container{width:100%;max-width:640px}.posts-list{flex-direction:column;display:flex}.new-posts-banner{background:var(--accent);color:#fff;border-radius:var(--radius);cursor:pointer;width:100%;transition:opacity var(--t);justify-content:center;align-items:center;margin-bottom:8px;padding:10px;font-size:13px;font-weight:600;display:flex}.new-posts-banner:hover{opacity:.88}.load-more-btn{border:1px dashed var(--border);border-radius:var(--radius);width:100%;color:var(--accent);transition:all var(--t);justify-content:center;align-items:center;gap:8px;margin:8px 0;padding:13px;font-size:14px;font-weight:600;display:flex}.load-more-btn:hover{border-style:solid;border-color:var(--accent);background:var(--accent-soft);box-shadow:var(--glow-sm)}.end-of-feed{text-align:center;color:var(--text-muted);letter-spacing:.2px;padding:28px;font-size:13px;font-weight:500}.profile-page{width:100%;max-width:640px}.profile-cover{background:var(--gradient-cover);border-radius:var(--radius);height:200px;box-shadow:var(--shadow);margin-bottom:-60px;position:relative;overflow:hidden}.profile-cover:after{content:"";background:linear-gradient(#0000 40%,#0d1b2e99 100%);position:absolute;inset:0}.profile-cover img{object-fit:cover;width:100%;height:100%}.profile-header{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);align-items:flex-end;gap:16px;margin-bottom:16px;padding:70px 24px 24px;display:flex;position:relative}.profile-avatar{border:3px solid var(--surface);width:100px;height:100px;box-shadow:var(--shadow), 0 0 0 2px var(--accent-mid), 0 0 20px var(--accent-glow);border-radius:50%;position:absolute;top:-56px;left:24px;overflow:hidden}.profile-avatar img{object-fit:cover;width:100%;height:100%;display:block}.profile-info{flex:1}.profile-info h2{letter-spacing:-.3px;margin-bottom:2px;font-size:21px;font-weight:800}.profile-username{color:var(--text-muted);margin-bottom:10px;font-size:14px;display:block}.profile-bio{color:var(--text-2);margin-bottom:12px;font-size:14px;line-height:1.5}.profile-stats{gap:22px;display:flex}.profile-stats span{color:var(--text-muted);flex-direction:column;font-size:13px;display:flex}.profile-stats strong{color:var(--text);font-size:18px;font-weight:700}.follow-btn{background:var(--gradient);color:#fff;box-shadow:var(--shadow-accent);transition:all var(--t);white-space:nowrap;border-radius:999px;flex-shrink:0;padding:9px 26px;font-size:14px;font-weight:700}.follow-btn:hover{opacity:.88;transform:translateY(-1px)}.follow-btn.following{color:var(--text-2);border:1px solid var(--border);box-shadow:none;background:0 0}.follow-btn.following:hover{border-color:var(--danger);color:var(--danger);background:var(--danger-soft)}.profile-actions{flex-shrink:0;align-items:center;gap:10px;display:flex}.message-btn{color:var(--accent);border:1px solid var(--accent);box-shadow:0 0 10px var(--accent-glow);transition:all var(--t);white-space:nowrap;background:0 0;border-radius:999px;flex-shrink:0;padding:9px 22px;font-size:14px;font-weight:700}.message-btn:hover{background:var(--accent-soft);box-shadow:0 0 16px var(--accent-glow);transform:translateY(-1px)}.edit-profile-btn{color:var(--text);border:1px solid var(--border);transition:all var(--t);white-space:nowrap;background:0 0;border-radius:999px;flex-shrink:0;padding:9px 22px;font-size:14px;font-weight:700}.edit-profile-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:500;background:#000000b3;justify-content:center;align-items:center;padding:16px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.edit-profile-modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:520px;max-height:90vh;box-shadow:var(--shadow), 0 0 60px #00000080;animation:.18s zoomIn;overflow-y:auto}.edit-profile-modal::-webkit-scrollbar{width:4px}.edit-profile-modal::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.epm-header{border-bottom:1px solid var(--border);background:var(--surface);z-index:1;justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex;position:sticky;top:0}.epm-header h3{font-size:17px;font-weight:700}.epm-close{width:34px;height:34px;color:var(--text-muted);transition:background var(--t), color var(--t);border-radius:50%;justify-content:center;align-items:center;display:flex}.epm-close:hover{background:var(--surface-2);color:var(--text)}.epm-cover-wrap{margin-bottom:52px;position:relative}.epm-cover{background:var(--gradient-cover);background-position:50%;background-size:cover;justify-content:center;align-items:center;height:150px;display:flex}.epm-photo-btn{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background var(--t);background:#0000008c;border-radius:999px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;display:flex}.epm-photo-btn:hover{background:#000000b8}.epm-avatar-wrap{width:88px;height:88px;position:absolute;bottom:-46px;left:20px}.epm-avatar{object-fit:cover;border:3px solid var(--surface);width:100%;height:100%;box-shadow:0 0 0 2px var(--accent-mid);border-radius:50%;display:block}.epm-avatar-btn{background:var(--accent);color:#fff;border:2px solid var(--surface);width:28px;height:28px;transition:background var(--t);border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;bottom:0;right:0}.epm-avatar-btn:hover{background:var(--accent-2)}.epm-fields{flex-direction:column;gap:16px;padding:8px 20px 20px;display:flex}.epm-field{flex-direction:column;gap:6px;display:flex}.epm-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:5px;font-size:12.5px;font-weight:600;display:flex}.epm-input{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);transition:border-color var(--t), box-shadow var(--t);outline:none;padding:10px 14px;font-family:inherit;font-size:14.5px}.epm-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.epm-input::placeholder{color:var(--text-muted)}.epm-textarea{resize:none;line-height:1.55}.epm-char-count{color:var(--text-muted);text-align:right;font-size:12px}.epm-toggle-row{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:row;justify-content:space-between;align-items:center;padding:12px 14px}.epm-toggle-info{color:var(--text-muted);align-items:center;gap:10px;display:flex}.epm-toggle-info .epm-label{margin:0}.epm-hint{color:var(--text-muted);text-transform:none;letter-spacing:0;margin-top:2px;font-size:12px;font-weight:400;display:block}.epm-hint a{color:#2aabee;text-decoration:none}.epm-hint a:hover{text-decoration:underline}.epm-toggle{background:var(--border);width:44px;height:24px;transition:background var(--t);border-radius:999px;flex-shrink:0;position:relative}.epm-toggle.on{background:var(--accent)}.epm-toggle-thumb{width:18px;height:18px;transition:transform var(--t);background:#fff;border-radius:50%;display:block;position:absolute;top:3px;left:3px}.epm-toggle.on .epm-toggle-thumb{transform:translate(20px)}.epm-footer{border-top:1px solid var(--border);background:var(--surface);justify-content:flex-end;gap:10px;padding:14px 20px;display:flex;position:sticky;bottom:0}.epm-cancel{color:var(--text-2);border:1px solid var(--border);transition:all var(--t);border-radius:999px;padding:9px 20px;font-size:14px;font-weight:600}.epm-cancel:hover{border-color:var(--text-2);color:var(--text)}.epm-save{background:var(--gradient);color:#fff;box-shadow:var(--shadow-accent);transition:opacity var(--t), transform var(--t);border-radius:999px;padding:9px 24px;font-size:14px;font-weight:700}.epm-save:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.epm-save:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.not-found{color:var(--text-muted);flex-direction:column;align-items:center;gap:12px;padding:80px 24px;font-size:16px;font-weight:500;display:flex}.notifications-page{width:100%;max-width:640px}.notifications-header{justify-content:space-between;align-items:center;padding:4px 0 20px;display:flex}.notifications-header h2{letter-spacing:-.3px;align-items:center;gap:10px;font-size:22px;font-weight:800;display:flex}.badge{background:var(--gradient);color:#fff;box-shadow:var(--shadow-accent);border-radius:999px;padding:2px 9px;font-size:11px;font-weight:700}.mark-all-btn{color:var(--accent);border-radius:var(--radius-xs);border:1px solid var(--accent-mid);transition:all var(--t);padding:7px 14px;font-size:13px;font-weight:600}.mark-all-btn:hover{background:var(--accent-soft);border-color:var(--accent)}.notifications-list{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.notif-item{border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--t);align-items:center;gap:13px;padding:15px 18px;display:flex}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--surface-2)}.notif-item.unread{background:var(--accent-soft)}.notif-item.unread:hover{background:var(--accent-mid)}.notif-avatar{object-fit:cover;border:1px solid var(--border);border-radius:50%;flex-shrink:0;width:42px;height:42px}.notif-body{flex:1;font-size:14px;line-height:1.5}.notif-username{color:var(--text);font-weight:700}.notif-message{color:var(--text-muted)}.notif-post-link{color:var(--accent);margin-left:4px;font-weight:500}.notif-post-link:hover{text-decoration:underline}.notif-time{color:var(--text-muted);white-space:nowrap;font-size:12px}.unread-dot{background:var(--accent);width:9px;height:9px;box-shadow:0 0 8px var(--accent-glow);border-radius:50%;flex-shrink:0;animation:2s infinite shimmer}.empty-state{color:var(--text-muted);flex-direction:column;align-items:center;gap:10px;padding:56px 24px;font-size:15px;font-weight:500;display:flex}.messages-page{background:var(--surface);border:none;border-radius:0;width:100%;height:100%;display:flex;overflow:hidden}.conversations-panel{border-right:1px solid var(--border);background:var(--surface-2);flex-direction:column;flex-shrink:0;width:290px;display:flex}.conversations-header{border-bottom:1px solid var(--border);padding:18px 16px 14px;position:relative}.conversations-header h3{letter-spacing:-.3px;margin-bottom:12px;font-size:19px;font-weight:800}.conv-search{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-3);width:100%;color:var(--text);transition:border-color var(--t), box-shadow var(--t);outline:none;padding:9px 14px;font-size:14px}.conv-search::placeholder{color:var(--text-muted)}.conv-search:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.search-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:0 0 var(--radius-sm) var(--radius-sm);box-shadow:var(--shadow-lg);z-index:50;border-top:none;max-height:260px;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.search-result{cursor:pointer;transition:background var(--t);align-items:center;gap:11px;padding:12px 16px;display:flex}.search-result:hover{background:var(--accent-soft)}.search-result img{object-fit:cover;border:1px solid var(--border);border-radius:50%;width:38px;height:38px}.search-result>div{flex-direction:column;gap:1px;display:flex}.search-result span{font-size:14px;font-weight:500}.muted{color:var(--text-muted)!important;font-size:12px!important;font-weight:400!important}.conv-list{flex:1;overflow-y:auto}.conv-item{cursor:pointer;border-bottom:1px solid var(--border-soft);transition:background var(--t);align-items:center;gap:12px;padding:13px 16px;display:flex}.conv-item:hover{background:var(--accent-soft)}.conv-item.active{background:var(--accent-soft);border-left:3px solid var(--accent);padding-left:13px;box-shadow:inset 0 0 20px #38bdf80d}.conv-avatar-wrap{flex-shrink:0;position:relative}.conv-avatar-wrap img{object-fit:cover;border:1px solid var(--border);border-radius:50%;width:46px;height:46px}.online-dot{background:var(--online);border:2px solid var(--surface-2);border-radius:50%;width:12px;height:12px;position:absolute;bottom:2px;right:2px;box-shadow:0 0 8px #34d39999}.conv-info{flex:1;min-width:0}.conv-info-top{justify-content:space-between;align-items:center;gap:6px;display:flex}.conv-info-bottom{justify-content:space-between;align-items:center;gap:6px;margin-top:2px;display:flex}.conv-name{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.conv-time{color:var(--text-muted);flex-shrink:0;font-size:11px}.conv-last{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:12.5px;overflow:hidden}.conv-last-unread{color:var(--text);font-weight:600}.conv-item.unread .conv-name{color:var(--text)}.conv-unread-dot{background:var(--accent);width:9px;height:9px;box-shadow:0 0 6px var(--accent-glow);border-radius:50%;flex-shrink:0}.chat-panel{flex-direction:column;flex:1;min-width:0;display:flex}.chat-header{border-bottom:1px solid var(--border);background:var(--surface);align-items:center;gap:13px;padding:15px 20px;display:flex}.chat-back-btn{width:34px;height:34px;color:var(--text-2);transition:background var(--t), color var(--t);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:none}.chat-back-btn:hover{background:var(--accent-soft);color:var(--accent)}@media (width<=768px){.chat-back-btn{display:flex}}.chat-header img{object-fit:cover;border:2px solid var(--accent-mid);border-radius:50%;width:40px;height:40px}.chat-name{font-size:15.5px;font-weight:700;display:block}.chat-status{margin-top:1px;font-size:12px;font-weight:500;display:block}.chat-status.online{color:var(--online)}.chat-status.offline{color:var(--text-muted)}.chat-messages{background:var(--bg);background-image:radial-gradient(at 20% 10%,#38bdf80a 0%,#0000 50%),radial-gradient(at 80% 90%,#6366f10a 0%,#0000 50%);flex-direction:column;flex:1;gap:8px;padding:20px;display:flex;overflow-y:auto}.chat-messages:before{content:"";flex:1}.message-bubble{max-width:65%;animation:popIn .15s var(--ease) both;border-radius:18px;padding:11px 16px;font-size:14.5px;line-height:1.55}.message-bubble.mine{background:var(--gradient);color:#fff;box-shadow:var(--shadow-accent);border-bottom-right-radius:5px;align-self:flex-end}.message-bubble.theirs{background:var(--surface);color:var(--text);border:1px solid var(--border);box-shadow:var(--shadow-xs);border-bottom-left-radius:5px;align-self:flex-start}.msg-image{border-radius:10px;max-width:100%;margin-bottom:6px;display:block}.msg-meta{justify-content:flex-end;align-items:center;gap:4px;margin-top:4px;display:flex}.msg-time{opacity:.6;font-size:10.5px}.msg-status{align-items:center;display:flex}.msg-status.sent{color:#ffffff80}.msg-status.seen{color:#38bdf8}.message-bubble.theirs .msg-status{display:none}.msg-seen-label{text-align:right;color:var(--accent);animation:fadeIn .2s var(--ease) both;margin-top:2px;padding-right:2px;font-size:10px;font-weight:600;display:block}.typing-indicator{color:var(--text-muted);background:var(--surface);border:1px solid var(--border);border-radius:18px 18px 18px 5px;align-self:flex-start;padding:8px 14px;font-size:13px;font-style:italic;animation:1.4s infinite pulse}.chat-input-form{padding:14px 18px calc(14px + env(safe-area-inset-bottom,0px));border-top:1px solid var(--border);background:var(--surface);gap:10px;display:flex}.chat-input{border:1px solid var(--border);background:var(--surface-2);color:var(--text);transition:border-color var(--t), box-shadow var(--t);border-radius:999px;outline:none;flex:1;padding:11px 18px;font-size:14.5px}.chat-input::placeholder{color:var(--text-muted)}.chat-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.chat-send-btn{background:var(--gradient);color:#fff;box-shadow:var(--shadow-accent);transition:opacity var(--t), transform var(--t);border-radius:999px;padding:11px 22px;font-size:14px;font-weight:700}.chat-send-btn:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.chat-send-btn:disabled{opacity:.35;cursor:not-allowed;box-shadow:none}.chat-emoji-btn{width:40px;height:40px;color:var(--text-muted);transition:background var(--t), color var(--t);border-radius:50%;flex-shrink:0;justify-content:center;align-self:center;align-items:center;display:flex}.chat-emoji-btn:hover,.chat-emoji-btn.active{background:var(--accent-soft);color:var(--accent)}.emoji-picker--chat{bottom:calc(100% + 10px);left:auto;right:0}.chat-empty{color:var(--text-muted);background:var(--bg);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:14px;font-size:15px;font-weight:500;display:flex}.explore-page{width:100%;max-width:640px}.explore-header{margin-bottom:20px}.explore-header h2{letter-spacing:-.3px;margin-bottom:14px;font-size:22px;font-weight:800}.tags-row{flex-wrap:wrap;gap:8px;display:flex}.tag-btn{border:1px solid var(--border);background:var(--surface);color:var(--text-muted);transition:all var(--t);border-radius:999px;padding:7px 18px;font-size:13.5px;font-weight:600}.tag-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.tag-btn.active{background:var(--gradient);color:#fff;box-shadow:var(--shadow-accent);border-color:#0000}.post-modal-overlay{z-index:500;animation:fadeIn .15s var(--ease) both;background:#000000b3;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.post-modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:620px;max-height:88vh;animation:slideUp .2s var(--ease) both;flex-direction:column;gap:16px;padding:24px;display:flex;position:relative;overflow-y:auto;box-shadow:0 24px 64px #0009}.post-modal-close{background:var(--surface-3);border:1px solid var(--border);width:32px;height:32px;color:var(--text);transition:background var(--t), border-color var(--t), transform var(--t);border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:14px;right:14px}.post-modal-close:hover{color:#ef4444;background:#ef444422;border-color:#ef4444;transform:scale(1.1)}.post-modal-loading{color:var(--text-muted);text-align:center;padding:24px 0;font-size:14px}.post-modal-header{align-items:center;display:flex}.post-modal-date{color:var(--text-muted);margin-top:2px;font-size:11px;display:block}.post-modal-content{color:var(--text);white-space:pre-wrap;font-size:15px;line-height:1.6}.post-modal-images{border-radius:var(--radius-sm);overflow:hidden}.post-modal-actions{border-top:1px solid var(--border);gap:10px;padding-top:4px;display:flex}.post-modal-comments{border-top:1px solid var(--border);padding-top:4px}.explore-grid{flex-direction:column;display:flex}.toast-container{z-index:9999;pointer-events:none;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:24px;right:24px}.toast{border-radius:var(--radius-sm);background:var(--card);border:1px solid var(--border);pointer-events:all;align-items:center;gap:10px;min-width:260px;max-width:380px;padding:12px 16px;animation:.25s toast-in;display:flex;box-shadow:0 4px 20px #00000040}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.toast--success .toast-icon{color:#22c55e}.toast--error .toast-icon{color:#ef4444}.toast--info .toast-icon{color:#3b82f6}.toast--success{border-left:3px solid #22c55e}.toast--error{border-left:3px solid #ef4444}.toast--info{border-left:3px solid #3b82f6}.toast-message{color:var(--text);flex:1;font-size:14px;line-height:1.4}.toast-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:4px;flex-shrink:0;align-items:center;padding:2px;display:flex}.toast-close:hover{color:var(--text)}@media (width<=768px){.hide-mobile{display:none!important}}@media (width>=769px){.hide-desktop{display:none!important}}.mobile-user-menu{position:relative}.mobile-user-trigger{border:2px solid var(--accent-mid);cursor:pointer;width:34px;height:34px;transition:box-shadow var(--t);border-radius:50%;flex-shrink:0;padding:0;overflow:hidden}.mobile-user-trigger:hover{box-shadow:0 0 0 3px var(--accent-glow)}.mobile-user-trigger img{object-fit:cover;width:100%;height:100%;display:block}.mobile-menu-panel{top:calc(var(--topbar-h) + 6px);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:min(280px,100vw - 24px);box-shadow:var(--shadow-lg);z-index:400;animation:fadeIn .15s var(--ease);position:fixed;right:12px;overflow:hidden}.mobile-menu-profile{transition:background var(--t);align-items:center;gap:10px;padding:14px;text-decoration:none;display:flex}.mobile-menu-profile:hover{background:var(--surface-3)}.mobile-menu-avatar{object-fit:cover;border:2px solid var(--accent-mid);border-radius:50%;flex-shrink:0;width:42px;height:42px}.mobile-menu-name{color:var(--text);margin:0;font-size:14px;font-weight:700}.mobile-menu-handle{color:var(--text-muted);margin:0;font-size:12px}.mobile-menu-divider{background:var(--border);height:1px}.mobile-menu-item{width:100%;color:var(--text);text-align:left;transition:background var(--t);align-items:center;gap:10px;padding:12px 14px;font-size:14px;display:flex}.mobile-menu-item:hover{background:var(--surface-3)}.mobile-menu-font-icon{text-align:center;flex-shrink:0;width:16px;font-size:13px;font-weight:800}.mobile-menu-chevron{color:var(--text-muted);transition:transform var(--t);flex-shrink:0;margin-left:auto}.mobile-menu-chevron.open{transform:rotate(90deg)}.mobile-menu-font-list{background:var(--bg);border-top:1px solid var(--border);max-height:180px;overflow-y:auto}.mobile-font-option{width:100%;color:var(--text);text-align:left;transition:background var(--t), color var(--t);padding:9px 14px 9px 40px;font-size:13px;display:block}.mobile-font-option:hover{background:var(--surface-3)}.mobile-font-option.active{color:var(--accent);background:var(--accent-soft);font-weight:700}.mobile-menu-logout{color:#f87171}.mobile-menu-logout:hover{background:#f8717114}.font-picker-wrap{position:relative}.font-picker-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:400;width:230px;max-height:70vh;animation:fadeIn .15s var(--ease);padding:14px;position:absolute;top:calc(100% + 10px);right:0;overflow-y:auto}.font-picker-section{flex-direction:column;gap:6px;display:flex}.font-picker-label{text-transform:uppercase;letter-spacing:.7px;color:var(--text-muted);margin:0;font-size:10.5px;font-weight:700}.font-picker-options{flex-direction:column;gap:1px;display:flex}.font-option{border-radius:var(--radius-sm);color:var(--text);text-align:left;transition:background var(--t), color var(--t);cursor:pointer;white-space:nowrap;text-overflow:ellipsis;padding:7px 10px;font-size:13px;overflow:hidden}.font-option:hover{background:var(--surface-3)}.font-option.active{background:var(--accent-soft);color:var(--accent);font-weight:700}.font-picker-divider{background:var(--border);height:1px;margin:10px 0}@media (width<=600px){.font-picker-panel{top:calc(var(--topbar-h) + 6px);width:auto;max-height:calc(100dvh - var(--topbar-h) - 24px);position:fixed;left:12px;right:12px;overflow-y:auto}}.theme-toggle{border-radius:var(--radius-sm);width:34px;height:34px;color:var(--text-muted);cursor:pointer;transition:background var(--t) var(--ease), color var(--t) var(--ease);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.theme-toggle:hover,.theme-toggle.active{background:var(--accent-soft);color:var(--accent)}@media (width<=900px){.new-post-page{max-width:100%;padding:16px 12px}.new-post-options{padding:10px 16px 12px}}@media (width<=768px){.messages-page{flex-direction:column}.conversations-panel{border-right:none;border-bottom:1px solid var(--border);width:100%}.messages-page:has(.chat-header) .conversations-panel{display:none}.app-layout:has(.messages-page .chat-header) .topbar{display:none}.app-layout:has(.messages-page .chat-header) .main-content--messages{height:var(--chat-h,100dvh);margin-top:0;position:fixed;top:0;left:0;right:0}.app-layout:has(.messages-page .chat-header) .chat-header{padding-top:calc(13px + env(safe-area-inset-top,0px))}.messages-page:has(.chat-empty) .chat-panel{display:none}.chat-panel{min-width:100%}.post-modal-overlay{padding:12px}.post-modal{gap:12px;max-width:100%;max-height:92vh;padding:18px 16px}.edit-profile-modal{max-width:100%;max-height:92vh}.profile-cover{border-radius:var(--radius-sm);height:150px;margin-bottom:-50px}.profile-header{flex-direction:column;align-items:stretch;gap:12px;padding:60px 16px 16px}.profile-avatar{width:84px;height:84px;top:-46px;left:16px}.profile-info h2{font-size:19px}.post-card{border-radius:var(--radius-sm);padding:16px}.post-avatar{width:40px;height:40px}.lightbox-prev{left:8px}.lightbox-next{right:8px}}@media (width<=640px){.auth-card{padding:28px 22px}.auth-logo{height:180px;margin:-28px -22px 20px}.auth-title{font-size:26px}.auth-guest-btn{padding:11px;font-size:13.5px}.comment-guest-prompt{padding:10px 12px;font-size:13px}.new-post-compose{gap:10px;padding:16px 14px 10px}.new-post-avatar{width:40px;height:40px}.new-post-options{gap:12px;padding:10px 14px 12px}.new-post-location{width:100%;min-width:0}.new-post-textarea{min-height:120px;font-size:16px}.new-post-footer{flex-wrap:wrap;padding:10px 14px}.emoji-picker{width:min(320px,100vw - 32px)}.emoji-picker--chat{left:auto;right:0}.emoji-grid{grid-template-columns:repeat(7,1fr)}.message-bubble{max-width:82%;padding:10px 14px;font-size:14px}.chat-messages{padding:14px 12px}.chat-header{padding:env(safe-area-inset-top,0px) 14px 12px;gap:10px}.chat-header img{width:36px;height:36px}.chat-input-form{padding:10px 12px calc(10px + env(safe-area-inset-bottom,0px))}.conversations-header{padding:14px 14px 12px}.notifications-header h2{font-size:19px}.notifications-header{padding:0 0 14px}.post-edit-toolbar{flex-wrap:wrap;gap:6px}.post-edit-visibility-select{flex:1;min-width:0}.post-edit-images-preview{gap:6px}.post-edit-image-wrap{width:72px;height:72px}.lightbox-close{top:10px;right:10px}.replies-list{padding-left:8px}.reply-avatar{width:22px;height:22px}.comment-body{padding:8px 10px}}@media (width<=420px){.main-content{padding:8px 10px calc(64px + env(safe-area-inset-bottom))}.replies-list{padding-left:6px}.comment-item{gap:6px}.comment-avatar{width:28px;height:28px}.auth-card{border-radius:var(--radius);padding:22px 16px}.auth-logo{border-radius:var(--radius) var(--radius) 0 0;height:160px;margin:-22px -16px 18px}.auth-title{font-size:24px}.topbar-sign-in{padding:5px 7px;font-size:11.5px}.auth-guest-btn{padding:10px;font-size:13px}.comment-guest-prompt{padding:8px 10px;font-size:12.5px}.topbar-logo span{display:none}.topbar-link{padding:8px}.post-card{padding:14px}.post-content{font-size:14.5px}.profile-cover{height:130px;margin-bottom:-44px}.profile-avatar{width:74px;height:74px;top:-40px}.profile-info h2{font-size:18px}.emoji-grid{grid-template-columns:repeat(6,1fr)}.chat-name{font-size:14.5px}.new-post-header{padding:12px 14px}.new-post-title{font-size:16px}.post-edit-toolbar{flex-direction:column;align-items:stretch}.post-edit-add-img-btn,.post-edit-visibility-select{justify-content:center;width:100%}.post-edit-image-wrap{width:64px;height:64px}.notif-item{gap:10px;padding:11px 12px}.notif-avatar{width:36px;height:36px}.notif-body{font-size:13px}.notif-time{font-size:11px}}
