@keyframes call-pulse{0%,to{transform:scale(1);opacity:.6}50%{transform:scale(1.18);opacity:0}}@keyframes call-pulse-2{0%,to{transform:scale(1);opacity:.3}50%{transform:scale(1.35);opacity:0}}@keyframes call-ring{0%,to{transform:rotate(0)}10%{transform:rotate(14deg)}20%{transform:rotate(-10deg)}30%{transform:rotate(8deg)}40%{transform:rotate(-6deg)}50%{transform:rotate(0)}}@keyframes co-fadeIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes co-fadeSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.co-overlay{position:fixed;inset:0;z-index:300;display:flex;flex-direction:column;background:#0f172a;animation:co-fadeIn .2s ease-out}.co-main{flex:1;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:radial-gradient(ellipse at 50% 40%,#1e293b,#0f172a 70%)}.co-center{display:flex;flex-direction:column;align-items:center;gap:18px;animation:co-fadeSlideUp .3s ease-out}.co-avatar-ring{position:relative;display:flex;align-items:center;justify-content:center}.co-avatar-ring:before,.co-avatar-ring:after{content:"";position:absolute;inset:-10px;border-radius:50%;border:2px solid rgba(34,197,94,.4);animation:call-pulse 2s ease-in-out infinite}.co-avatar-ring:after{inset:-20px;border-color:#22c55e33;animation:call-pulse-2 2s ease-in-out infinite .4s}.co-avatar-ring .avatar{width:112px;height:112px;font-size:44px;border:3px solid rgba(255,255,255,.1);box-shadow:0 12px 40px #0006}.co-partner-name{font-size:22px;font-weight:600;color:#fff;letter-spacing:-.01em}.co-status{font-size:14px;color:#ffffff80;font-variant-numeric:tabular-nums}.co-top-info{position:absolute;top:0;left:0;right:0;padding:16px 24px;display:flex;flex-direction:column;align-items:center;gap:2px;background:linear-gradient(to bottom,rgba(0,0,0,.6),transparent);z-index:5}.co-top-info .co-partner-name{font-size:16px}.co-top-info .co-status{font-size:13px;color:#ffffffb3}.co-remote-video{width:100%;height:100%;object-fit:cover}.co-local-pip{position:absolute;bottom:calc(110px + env(safe-area-inset-bottom,0px));right:16px;width:120px;height:160px;border-radius:12px;overflow:hidden;box-shadow:0 8px 32px #00000080;border:2px solid rgba(255,255,255,.15);background:#1f2937;z-index:10;object-fit:cover;transform:scaleX(-1)}.co-controls{padding:14px 24px calc(32px + env(safe-area-inset-bottom,0px));display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;background:#0f172ad9;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid rgba(255,255,255,.06)}.co-btn{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:all .15s;color:#fff;background:#ffffff1a}.co-btn:hover{transform:scale(1.08);background:#ffffff2e}.co-btn:active{transform:scale(.95)}.co-btn.active{background:#ffffff40;box-shadow:inset 0 0 0 2px #ffffff26}.co-btn-end{width:56px;height:56px;background:#ef4444;margin:0 6px}.co-btn-end:hover{background:#dc2626;transform:scale(1.08)}.co-btn-minimize{width:42px;height:42px;background:#ffffff0f}.co-pip{position:fixed;bottom:calc(76px + env(safe-area-inset-bottom,0px));right:16px;width:280px;height:180px;z-index:300;border-radius:16px;overflow:hidden;background:#0f172a;box-shadow:0 12px 48px #00000080;border:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;animation:co-fadeIn .2s ease-out;cursor:grab;touch-action:none}.co-pip:active{cursor:grabbing}.co-pip-main{flex:1;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:radial-gradient(ellipse at 50% 40%,#1e293b,#0f172a 70%)}.co-pip-center{display:flex;flex-direction:column;align-items:center;gap:6px}.co-pip-center .avatar{width:48px;height:48px;font-size:20px}.co-pip-name{font-size:13px;font-weight:600;color:#fff;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.co-pip-timer{font-size:12px;color:#ffffff80;font-variant-numeric:tabular-nums}.co-pip .co-remote-video{width:100%;height:100%;object-fit:cover}.co-pip-controls{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px;background:#0f172ae6;border-top:1px solid rgba(255,255,255,.06)}.co-pip-controls .co-btn{width:36px;height:36px}.co-pip-controls .co-btn-end{width:40px;height:40px}.co-pip-expand{width:32px;height:32px;background:#ffffff0f}.co-incoming{position:fixed;inset:0;z-index:350;display:flex;align-items:center;justify-content:center;background:#000000a6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.co-incoming-card{background:#1e293beb;border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:28px 36px 24px;display:flex;flex-direction:column;align-items:center;gap:10px;min-width:240px;box-shadow:0 20px 60px #00000080;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);animation:co-fadeIn .25s ease-out}.co-incoming-icon{font-size:28px;animation:call-ring 1.5s ease-in-out infinite;margin-bottom:2px}.co-incoming-avatar .avatar{width:76px;height:76px;font-size:30px;border:2px solid rgba(255,255,255,.1)}.co-incoming-name{font-size:19px;font-weight:600;color:#fff}.co-incoming-type{font-size:13px;color:#ffffff73}.co-incoming-actions{display:flex;gap:20px;margin-top:10px}.co-incoming-btn{width:54px;height:54px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:all .15s}.co-incoming-btn:hover{transform:scale(1.08)}.co-incoming-btn:active{transform:scale(.95)}.co-incoming-btn-accept{background:#22c55e}.co-incoming-btn-accept:hover{background:#16a34a}.co-incoming-btn-reject{background:#ef4444}.co-incoming-btn-reject:hover{background:#dc2626}@media(max-width:768px){.co-pip{width:240px;height:160px;bottom:calc(66px + env(safe-area-inset-bottom,0px));right:8px}}.ro-overlay{position:fixed;inset:0;z-index:300;display:flex;flex-direction:column;background:#0f172a;animation:co-fadeIn .2s ease-out}.ro-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:#0f172ae6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2;border-bottom:1px solid rgba(255,255,255,.06)}.ro-room-name{font-size:16px;font-weight:600;color:#fff}.ro-room-info{display:flex;align-items:center;gap:8px;font-size:13px;color:#ffffff80}.ro-timer{font-variant-numeric:tabular-nums}.ro-invite-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;border:1px solid rgba(255,255,255,.15);background:#ffffff14;color:#fff;font-size:13px;cursor:pointer;transition:background .2s}.ro-invite-btn:hover{background:#ffffff26}.ro-invite-btn.copied{border-color:#22c55e;color:#22c55e}.ro-grid{flex:1;display:grid;gap:6px;padding:6px;overflow:hidden}.ro-grid[data-count="1"]{grid-template-columns:1fr}.ro-grid[data-count="2"]{grid-template-columns:1fr 1fr}.ro-grid[data-count="3"]{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.ro-grid[data-count="3"] .ro-cell:first-child{grid-column:1 / -1}.ro-grid[data-count="4"]{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.ro-grid[data-count="5"],.ro-grid[data-count="6"]{grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr}.ro-grid[data-count="7"],.ro-grid[data-count="8"],.ro-grid[data-count="9"]{grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr 1fr}.ro-cell{position:relative;background:#1e293b;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center}.ro-cell video{width:100%;height:100%;object-fit:cover;border-radius:12px}.ro-cell.local video{transform:scaleX(-1)}.ro-label{position:absolute;bottom:8px;left:8px;display:flex;align-items:center;gap:6px;padding:4px 10px;background:#0009;border-radius:16px;font-size:12px;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.ro-muted-icon{color:#ef4444}.ro-no-video{display:flex;flex-direction:column;align-items:center;gap:8px;color:#fff6}.ro-no-video .avatar{width:72px;height:72px;font-size:26px;line-height:72px}.ro-screen-sharing{background:linear-gradient(135deg,#1a2a3a,#1e3a4a)}.ro-screen-icon{color:var(--primary);margin-bottom:8px;opacity:.8}.ro-no-video-name{font-size:14px;color:#fff9}.ro-controls{padding:14px 24px calc(14px + env(safe-area-inset-bottom,0px));display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;background:#0f172ae6;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid rgba(255,255,255,.06)}.ro-btn{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:all .15s;color:#fff;background:#ffffff1a}.ro-btn:hover{transform:scale(1.08);background:#ffffff2e}.ro-btn:active{transform:scale(.95)}.ro-btn.active{background:#ffffff40;box-shadow:inset 0 0 0 2px #ffffff26}.ro-btn-end{width:56px;height:56px;background:#ef4444;margin:0 6px}.ro-btn-end:hover{background:#dc2626;transform:scale(1.08)}.ro-btn-minimize{width:42px;height:42px;background:#ffffff0f}.ro-pip{position:fixed;bottom:calc(76px + env(safe-area-inset-bottom,0px));right:16px;width:300px;height:200px;z-index:300;border-radius:16px;overflow:hidden;background:#0f172a;box-shadow:0 12px 48px #00000080;border:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;animation:co-fadeIn .2s ease-out;cursor:grab;touch-action:none}.ro-pip:active{cursor:grabbing}.ro-pip-main{flex:1;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:radial-gradient(ellipse at 50% 40%,#1e293b,#0f172a 70%)}.ro-pip-main video,.ro-pip-video{width:100%;height:100%;object-fit:cover}.ro-pip-info{position:absolute;top:6px;left:8px;display:flex;align-items:center;gap:5px;padding:3px 8px;background:#0009;border-radius:12px;font-size:11px;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.ro-pip-timer{font-variant-numeric:tabular-nums;color:#fff9}.ro-pip-controls{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px;background:#0f172af2;border-top:1px solid rgba(255,255,255,.06)}.ro-pip-controls .ro-btn{width:36px;height:36px}.ro-pip-controls .ro-btn-end{width:40px;height:40px}.ro-pip-expand{width:32px!important;height:32px!important;background:#ffffff0f}@media(max-width:768px){.ro-grid[data-count="2"]{grid-template-columns:1fr;grid-template-rows:1fr 1fr}.ro-grid[data-count="3"],.ro-grid[data-count="4"]{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.ro-grid[data-count="3"] .ro-cell:first-child{grid-column:auto}.ro-grid[data-count="5"],.ro-grid[data-count="6"],.ro-grid[data-count="7"],.ro-grid[data-count="8"],.ro-grid[data-count="9"]{grid-template-columns:1fr 1fr}.ro-header{padding:8px 12px}.ro-controls{padding:12px;gap:10px}.ro-btn{width:46px;height:46px}.ro-btn-end{width:52px;height:52px}.ro-pip{width:260px;height:180px;bottom:calc(66px + env(safe-area-inset-bottom,0px));right:8px}}.layout{min-height:100vh;display:flex;flex-direction:column}.layout-body{margin-top:calc(var(--header-height) + env(safe-area-inset-top,0px));min-height:calc(100vh - var(--header-height) - env(safe-area-inset-top,0px));width:1100px;max-width:100%;margin-left:auto;margin-right:auto;display:flex}.header{position:fixed;top:0;left:0;right:0;height:calc(var(--header-height) + env(safe-area-inset-top,0px));padding-top:env(safe-area-inset-top,0px);background:var(--bg-card);border-bottom:1px solid var(--border);z-index:100;box-shadow:var(--shadow-sm)}.header-inner{width:1100px;max-width:100%;margin:0 auto;height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 16px}.header-left,.header-right{display:flex;align-items:center;gap:12px;min-width:200px}.header-right{justify-content:flex-end}.logo{display:flex;align-items:center;gap:8px;cursor:pointer}.logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--primary),var(--green-600));color:#fff;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px;letter-spacing:-1px}.logo-text{font-size:var(--font-size-xl);font-weight:700;color:var(--green-700)}.header-center{flex:1;max-width:480px;margin:0 24px}.search-bar{display:flex;align-items:center;gap:8px;background:var(--bg-main);border:1px solid var(--border-light);border-radius:var(--radius-full);padding:8px 16px;color:var(--text-muted);transition:all var(--transition);width:100%}.search-bar:focus-within{border-color:var(--border-focus);background:#fff;box-shadow:0 0 0 3px #4ade801a}.search-input{border:none;outline:none;background:transparent;font-size:var(--font-size-md);color:var(--text-primary);width:100%}.header-btn{position:relative;width:38px;height:38px;border:none;background:var(--bg-main);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:all var(--transition)}.header-btn:hover{background:var(--primary-light);color:var(--green-700)}.notif-wrapper{position:relative}.notif-badge{position:absolute;top:-2px;right:-2px;min-width:18px;height:18px;background:var(--error);color:#fff;border-radius:9px;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1}.notif-panel{position:absolute;top:calc(100% + 8px);right:0;width:380px;max-height:480px;background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:0 8px 30px #00000026;border:1px solid var(--border-light);z-index:500;display:flex;flex-direction:column;overflow:hidden;animation:notifSlideIn .15s ease-out}@keyframes notifSlideIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.notif-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border-light)}.notif-title{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary)}.notif-read-all{display:flex;align-items:center;gap:4px;background:none;border:none;cursor:pointer;font-size:var(--font-size-sm);color:var(--green-600);font-weight:500;padding:4px 8px;border-radius:var(--radius-md);transition:background var(--transition)}.notif-read-all:hover{background:var(--primary-light)}.notif-list{overflow-y:auto;flex:1;max-height:420px}.notif-empty{padding:40px 16px;text-align:center;color:var(--text-muted);font-size:var(--font-size-md)}.notif-item{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background var(--transition);position:relative}.notif-item:hover{background:var(--bg-hover)}.notif-item.unread{background:#4ade800f}.notif-item.unread:hover{background:#4ade801f}.notif-item-avatar{position:relative;flex-shrink:0}.notif-item-type-icon{position:absolute;bottom:-2px;right:-4px;width:20px;height:20px;background:var(--bg-card);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--green-600);border:1.5px solid var(--border-light)}.notif-item-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.notif-item-text{font-size:var(--font-size-sm);color:var(--text-primary);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notif-item.unread .notif-item-text{font-weight:600}.notif-item-time{font-size:11px;color:var(--text-muted)}.notif-item-dot{width:8px;height:8px;background:var(--green-500);border-radius:50%;flex-shrink:0}.header-user{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:var(--radius-md);transition:all var(--transition)}.header-user:hover{background:var(--bg-hover)}.header-username{font-weight:500;font-size:var(--font-size-sm)}.sidebar{width:var(--sidebar-width);flex-shrink:0;position:sticky;top:calc(var(--header-height) + env(safe-area-inset-top,0px));height:calc(100vh - var(--header-height) - env(safe-area-inset-top,0px));background:var(--bg-sidebar);border-right:1px solid var(--border-light);padding:8px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.sidebar-profile{display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition)}.sidebar-profile:hover{background:var(--bg-hover)}.sidebar-profile-info{display:flex;flex-direction:column}.sidebar-profile-name{font-weight:600;font-size:var(--font-size-md)}.sidebar-profile-community{font-size:var(--font-size-xs);color:var(--text-muted)}.nav-item{position:relative;display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius-md);color:var(--text-primary);font-size:15px;font-weight:500;cursor:pointer;border:none;background:none;width:100%;text-align:left;text-decoration:none;transition:all var(--transition)}.nav-item:hover{background:var(--bg-hover);text-decoration:none}.nav-item.active{background:var(--primary-light);color:var(--green-700);font-weight:600}.nav-icon{width:28px;display:flex;align-items:center;justify-content:center}.nav-badge{position:absolute;right:10px;background:var(--error);color:#fff;font-size:11px;font-weight:700;padding:1px 7px;border-radius:var(--radius-full)}.nav-shortcut{color:var(--text-secondary);font-size:var(--font-size-sm)}.sidebar-section-title{font-size:var(--font-size-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:8px 14px 4px}.sidebar-spacer{flex:1}.sidebar-footer{padding-top:4px}.sidebar-footer .nav-item{color:var(--text-muted);font-size:var(--font-size-sm)}.sidebar-footer .nav-item:hover{color:var(--error)}.sidebar-divider{height:1px;background:var(--border-light);margin:8px 14px}.main-content{flex:1;min-width:0;padding:16px 20px;min-height:calc(100vh - var(--header-height))}.mobile-bar{display:none}@media(max-width:768px){.sidebar{display:none}.mobile-bar{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--bg-card);border-top:1px solid var(--border-light);box-shadow:0 -2px 10px #0000000f;z-index:200;padding:0;padding-bottom:env(safe-area-inset-bottom,0)}.mobile-bar-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-height:56px;font-size:10px;color:var(--text-muted);text-decoration:none;-webkit-tap-highlight-color:transparent;transition:color .15s;position:relative;cursor:pointer}.mobile-bar-item.active{color:var(--green-600)}.mobile-bar-item.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:32px;height:3px;background:var(--green-500);border-radius:0 0 3px 3px}.mobile-bar-icon{position:relative;display:flex;align-items:center;justify-content:center;width:48px;height:30px}.mobile-bar-item.active .mobile-bar-icon{background:var(--primary-light);border-radius:var(--radius-full)}.mobile-bar-label{font-weight:500;letter-spacing:.01em}.mobile-bar-item.active .mobile-bar-label{font-weight:600;color:var(--green-700)}.mobile-bar-badge{position:absolute;top:0;right:2px;min-width:16px;height:16px;background:var(--error);color:#fff;font-size:9px;font-weight:700;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1}.layout-body{padding-bottom:calc(56px + env(safe-area-inset-bottom,0px))}.main-content{padding:8px;overflow-x:hidden}.header-center{display:none}.notif-panel{position:fixed;top:calc(var(--header-height) + 4px);left:16px;right:16px;width:auto;max-height:calc(100vh - var(--header-height) - 70px - env(safe-area-inset-bottom,0px))}.header-left .logo-text{display:none}.header-left,.header-right{min-width:auto}}.mobile-only{display:none}@media(max-width:768px){.mobile-only{display:flex}}@media all and (display-mode:standalone){.header-inner{padding-left:max(16px,env(safe-area-inset-left,0px));padding-right:max(16px,env(safe-area-inset-right,0px))}.mobile-bar{padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px)}}.push-enable-banner{display:flex;align-items:center;gap:8px;width:100%;padding:12px 16px;border:none;background:linear-gradient(135deg,var(--primary-light),#dcfce7);color:var(--green-700);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--border-light)}.push-enable-banner:hover{background:#bbf7d0}.push-denied-banner{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#fef3c7;color:#92400e;font-size:12px;border-bottom:1px solid #fde68a}.text-size-fab{display:none}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-main) 0%,var(--pastel-mint) 50%,var(--pastel-lime) 100%);padding:20px}.auth-card{width:100%;max-width:420px;padding:40px 32px}.auth-logo{text-align:center;margin-bottom:28px;display:flex;flex-direction:column;align-items:center;gap:8px}.auth-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--green-700)}.auth-subtitle{color:var(--text-secondary);font-size:var(--font-size-md)}.auth-form{display:flex;flex-direction:column;gap:14px}.auth-row{display:flex;gap:10px}.auth-btn{width:100%;justify-content:center;padding:12px;font-size:var(--font-size-lg);font-weight:600;margin-top:4px}.auth-error{background:var(--pastel-rose);color:#be123c;padding:10px 14px;border-radius:var(--radius-md);font-size:var(--font-size-sm)}.auth-success{background:var(--pastel-mint);color:#15803d;padding:10px 14px;border-radius:var(--radius-md);font-size:var(--font-size-sm)}.auth-forgot{text-align:right;margin-top:-6px}.auth-forgot a{font-size:var(--font-size-sm);color:var(--text-muted)}.auth-forgot a:hover{color:var(--primary)}.auth-footer{text-align:center;margin-top:20px;color:var(--text-secondary);font-size:var(--font-size-sm)}.verify-code-inputs{display:flex;gap:8px;justify-content:center;margin-top:20px}.verify-digit{width:48px;height:56px;text-align:center;font-size:24px;font-weight:700;border:2px solid var(--border);border-radius:var(--radius-md);background:var(--bg-input);color:var(--text-primary);outline:none;transition:border-color var(--transition)}.verify-digit:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4ade8026}.auth-terms{font-size:var(--font-size-xs);color:var(--text-muted);text-align:center;line-height:1.5;padding:4px 0}.auth-terms a{color:var(--primary);text-decoration:underline}.legal-card{max-width:560px;max-height:85vh;overflow-y:auto}.legal-title{font-size:var(--font-size-xl);font-weight:700;color:var(--green-700);margin:0 0 4px}.legal-date{font-size:var(--font-size-xs);color:var(--text-muted);margin:0 0 20px}.legal-content h3{font-size:var(--font-size-md);font-weight:600;color:var(--text-primary);margin:16px 0 6px}.legal-content p{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.6;margin:0 0 8px}.legal-content ul{margin:0 0 8px;padding-left:20px}.legal-content li{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.6;margin-bottom:4px}.pw-wrap{position:relative;display:flex}.pw-wrap .input{flex:1;padding-right:42px}.pw-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;display:flex;align-items:center}.pw-toggle:hover{color:var(--text-primary)}@media(max-width:768px){.auth-card{padding:28px 20px}.auth-title{font-size:var(--font-size-xl)}.verify-digit{width:40px;height:48px;font-size:20px}.verify-code-inputs{gap:6px}.legal-card{max-height:80vh}}.feed{display:flex;flex-direction:column;gap:16px}.create-post{padding:16px}.create-post-top{display:flex;align-items:center;gap:12px;padding-bottom:12px;border-bottom:1px solid var(--border-light)}.create-post-input{flex:1;border:none;outline:none;font-size:var(--font-size-lg);color:var(--text-primary);background:transparent}.create-post-input::placeholder{color:var(--text-muted)}.create-post-actions{display:flex;align-items:center;gap:4px;padding-top:8px}.create-post-actions .btn-primary{margin-left:auto}.create-post-previews{display:flex;gap:8px;padding:8px 0;flex-wrap:wrap}.preview-thumb{position:relative;width:72px;height:72px;border-radius:var(--radius-md);overflow:hidden}.preview-thumb img{width:100%;height:100%;object-fit:cover}.preview-remove{position:absolute;top:2px;right:2px;width:22px;height:22px;border-radius:50%;background:#0009;color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer}.post{padding:16px}.post-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.post-author{display:flex;flex-direction:column;flex:1}.post-name{font-weight:600;font-size:var(--font-size-md)}.post-time{font-size:var(--font-size-xs);color:var(--text-muted)}.post-content{font-size:var(--font-size-lg);line-height:1.6;margin-bottom:12px;white-space:pre-wrap}.post-gallery{display:grid;gap:4px;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:12px}.gallery-1{grid-template-columns:1fr}.gallery-2,.gallery-3{grid-template-columns:1fr 1fr}.gallery-3 .post-gallery-img:first-child{grid-row:span 2}.gallery-4{grid-template-columns:1fr 1fr}.post-gallery-img{width:100%;height:240px;object-fit:cover;cursor:pointer}.gallery-1 .post-gallery-img{height:360px}.gallery-2 .post-gallery-img{height:200px}.post-stats{display:flex;gap:16px;padding:8px 0;border-top:1px solid var(--border-light);font-size:var(--font-size-sm);color:var(--text-secondary)}.post-actions{display:flex;border-top:1px solid var(--border-light);padding-top:8px}.post-action{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px;border:none;background:none;border-radius:var(--radius-md);font-size:var(--font-size-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition)}.post-action:hover{background:var(--bg-hover);color:var(--text-primary)}.post-action.liked{color:var(--error)}.btn-type-active{background:var(--primary-light)!important;color:var(--green-700)!important;font-weight:600}.post-action.active{color:var(--primary);background:var(--primary-light)}.post-action.shared{color:var(--green-700)}.comments-section{padding:12px 0 0;border-top:1px solid var(--border-light)}.comments-empty{text-align:center;color:var(--text-muted);font-size:var(--font-size-sm);padding:8px 0;margin:0}.comment{display:flex;gap:10px;padding:8px 0}.comment-body{display:flex;flex-direction:column;gap:2px;flex:1}.comment-author{font-weight:600;font-size:var(--font-size-sm)}.comment-text{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.4}.comment-time{font-size:var(--font-size-xs);color:var(--text-muted)}.comment-input-row{display:flex;align-items:center;gap:10px;padding-top:8px;border-top:1px solid var(--border-light);margin-top:4px}.comment-input{flex:1;border:1px solid var(--border);border-radius:var(--radius-full);padding:8px 14px;font-size:var(--font-size-sm);background:var(--bg-input);color:var(--text-primary);outline:none}.comment-input:focus{border-color:var(--primary)}.comment-reply{margin-left:32px}.comment-reply-to{font-size:var(--font-size-xs);color:var(--primary);display:flex;align-items:center;gap:4px}.comment-footer{display:flex;align-items:center;gap:12px;margin-top:2px}.comment-action{display:flex;align-items:center;gap:3px;border:none;background:none;padding:0;font-size:var(--font-size-xs);color:var(--text-muted);cursor:pointer;transition:color var(--transition)}.comment-action:hover{color:var(--text-primary)}.comment-action.liked{color:var(--error)}.comment-reply-bar{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;background:var(--primary-light);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--primary);margin-bottom:4px}.comment-reply-cancel{border:none;background:none;color:var(--text-muted);cursor:pointer;padding:2px;display:flex}.feed-empty{padding:40px;text-align:center;color:var(--text-muted)}.content-menu-wrap{position:relative;margin-left:auto;flex-shrink:0}.content-menu-btn{padding:4px!important;border-radius:50%!important;color:var(--text-muted)}.content-menu-btn:hover{color:var(--text-primary)}.content-menu{position:absolute;top:100%;right:0;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:0 8px 24px #0000001f;padding:4px;z-index:50;min-width:160px;animation:fadeIn .12s ease-out}.content-menu button{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--text-secondary);cursor:pointer;transition:background var(--transition)}.content-menu button:hover{background:var(--bg-hover);color:var(--text-primary)}.content-menu-danger{color:var(--error)!important}.content-menu-danger:hover{background:#ef444414!important;color:var(--error)!important}.post-edit-form{display:flex;flex-direction:column;gap:8px;padding:8px 0}.post-edit-form textarea,.post-edit-form input,.post-edit-form select{font-size:var(--font-size-md)}.post-edit-actions{display:flex;gap:8px;justify-content:flex-end}.forward-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000}.forward-modal{background:var(--bg-card);border-radius:var(--radius-lg);width:90%;max-width:400px;max-height:70vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0003}.forward-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border-light)}.forward-header h3{margin:0;font-size:var(--font-size-lg)}.forward-list{overflow-y:auto;padding:8px}.forward-empty{text-align:center;color:var(--text-muted);padding:24px;margin:0}.forward-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;border:none;background:none;border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-md);color:var(--text-primary);transition:background var(--transition)}.forward-item:hover{background:var(--bg-hover)}.forward-item:disabled{opacity:.5;cursor:wait}@media(max-width:768px){.create-post{padding:12px}.create-post-input{font-size:var(--font-size-md)}.create-post-actions{flex-wrap:wrap;gap:6px}.create-post-actions .btn{font-size:var(--font-size-xs);padding:5px 8px;white-space:nowrap}.create-post-actions .btn-primary{width:100%;margin-left:0;font-size:var(--font-size-sm);padding:8px 14px;justify-content:center}.post{padding:12px}.post-content{font-size:var(--font-size-md)}.post-actions{flex-wrap:wrap}.post-action{font-size:var(--font-size-xs);padding:6px 4px;gap:3px;min-width:0}.comment-input-row{flex-wrap:wrap;gap:8px}.comment-input{min-width:0}.feed-empty{padding:24px}}.messenger{display:flex;height:calc(100vh - var(--header-height) - 32px);background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-light);overflow:hidden}.messenger-sidebar{width:340px;flex-shrink:0;border-right:1px solid var(--border-light);display:flex;flex-direction:column;transition:width .25s,opacity .25s}.messenger-sidebar.sidebar-hidden{width:0;overflow:hidden;border-right:none;opacity:0;pointer-events:none}.sidebar-toggle-btn{padding:6px;color:var(--text-muted);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md)}.sidebar-toggle-btn:hover{color:var(--primary)}.messenger-sidebar-header{padding:16px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between}.messenger-sidebar-header h2{font-size:var(--font-size-xl);font-weight:700}.new-chat-btn{padding:6px;border-radius:var(--radius-md);color:var(--text-secondary)}.new-chat-btn:hover{color:var(--primary)}.messenger-search{display:flex;align-items:center;gap:8px;margin:8px 12px;padding:8px 12px;background:var(--bg-main);border-radius:var(--radius-full);color:var(--text-muted)}.messenger-search input{border:none;outline:none;background:transparent;font-size:var(--font-size-sm);width:100%}.search-clear{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:2px;display:flex}.search-clear:hover{color:var(--text-primary)}.search-results{flex:1;overflow-y:auto;padding:4px}.search-results-label{font-size:var(--font-size-xs);color:var(--text-muted);padding:8px 12px 4px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.conv-list{flex:1;overflow-y:auto;padding:4px}.conv-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition)}.conv-item:hover{background:var(--bg-hover)}.conv-item.active{background:var(--primary-light)}.conv-avatar-wrap{position:relative;flex-shrink:0}.conv-avatar-wrap .avatar,.chat-header-avatar .avatar{outline:2.5px solid #f87171;outline-offset:1.5px;transition:outline-color .3s}.conv-avatar-wrap.status-online .avatar,.chat-header-avatar.status-online .avatar{outline-color:#22c55e}.conv-avatar-wrap.status-offline .avatar,.chat-header-avatar.status-offline .avatar{outline-color:#f87171}.conv-avatar-wrap.status-system .avatar,.chat-header-avatar.status-system .avatar{outline-color:#22c55e;animation:systemPulse 3s ease-in-out infinite}@keyframes systemPulse{0%,to{outline-color:#22c55e}50%{outline-color:#16a34a}}.conv-avatar-wrap.status-group .avatar,.chat-header-avatar.status-group .avatar{outline:none;border:2.5px solid transparent;background-image:linear-gradient(var(--bg-card),var(--bg-card)),linear-gradient(135deg,#14b8a6,#22c55e);background-origin:border-box;background-clip:padding-box,border-box}.conv-info{flex:1;min-width:0}.conv-top-row{display:flex;justify-content:space-between;align-items:baseline}.conv-name{font-weight:600;font-size:var(--font-size-md)}.conv-time{font-size:var(--font-size-xs);color:var(--text-muted);flex-shrink:0}.conv-bottom-row{display:flex;align-items:center;gap:8px}.conv-last{font-size:var(--font-size-sm);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.conv-unread{width:20px;height:20px;background:var(--primary);color:#fff;border-radius:50%;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.conv-empty{padding:40px 20px;text-align:center;color:var(--text-muted)}.messenger-chat{flex:1;display:flex;flex-direction:column;min-width:0;overflow-x:hidden}.chat-header{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border-light)}.chat-header-avatar{position:relative;flex-shrink:0}.chat-header-info{display:flex;flex-direction:column;flex:1;min-width:0}.chat-header-name{font-weight:600;font-size:var(--font-size-md);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-header-status{font-size:var(--font-size-xs);color:var(--green-600)}.chat-header-actions{margin-left:auto;display:flex;align-items:center;gap:4px}.chat-header-actions .wp-picker-wrap>.emoji-toggle,.chat-header-actions .snd-picker-wrap>.emoji-toggle{display:none}.chat-header-actions .wp-picker-wrap,.chat-header-actions .snd-picker-wrap{width:0;overflow:visible}.mobile-back{display:none;align-items:center;gap:4px;padding:6px 12px 6px 8px;border:none;border-radius:var(--radius-full);background:var(--primary-light);color:var(--green-700);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s;flex-shrink:0}.mobile-back:active{background:var(--accent-soft)}.wp-picker-wrap{position:relative}.wp-picker{position:absolute;top:42px;right:0;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:0 8px 24px #0000001f;padding:8px;display:flex;gap:8px;z-index:100}.wp-opt{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;padding:6px;border-radius:var(--radius-md);transition:background var(--transition);font-size:var(--font-size-xs);color:var(--text-secondary)}.wp-opt:hover{background:var(--bg-hover)}.wp-opt.active{background:var(--primary-light);color:var(--primary);font-weight:600}.wp-preview{width:56px;height:40px;border-radius:var(--radius-sm);border:1.5px solid var(--border-light);display:flex;align-items:center;justify-content:center;font-size:10px;overflow:hidden}.wp-opt.active .wp-preview{border-color:var(--primary)}.wp-prev-default{background:var(--bg-card)}.wp-prev-village{background:#f2f8ee}.wp-prev-social{background:#f0edff}.wp-prev-hearts{background:linear-gradient(to bottom,#f8c8d4,#7ec8c8)}.wp-prev-dark{background:linear-gradient(135deg,#111 60%,#c8e600)}.snd-picker-wrap{position:relative}.snd-picker{position:absolute;top:42px;right:0;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:0 8px 24px #0000001f;padding:6px;display:flex;flex-direction:column;gap:2px;z-index:100;min-width:160px;animation:fadeIn .12s ease-out}.snd-toggle{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary);transition:background var(--transition);border-bottom:1px solid var(--border-light);margin-bottom:2px}.snd-toggle:hover{background:var(--bg-hover)}.snd-opt{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm);color:var(--text-secondary);transition:background var(--transition);white-space:nowrap}.snd-opt:hover{background:var(--bg-hover)}.snd-opt.active{background:var(--primary-light);color:var(--primary);font-weight:600}.snd-opt-icon{font-size:14px;flex-shrink:0}.snd-tabs{display:flex;gap:0;border-bottom:1px solid var(--border-light);margin-bottom:4px}.snd-tab{flex:1;padding:7px 6px;border:none;background:none;font-size:var(--font-size-xs);font-weight:500;color:var(--text-secondary);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;white-space:nowrap}.snd-tab:hover{color:var(--text-primary)}.snd-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.typing-text{color:var(--green-600);font-style:italic}.chat-messages-wrap{flex:1;position:relative;overflow:hidden;min-height:0}.chat-wp{position:absolute;inset:0;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:0;background-size:280px 200px;background-repeat:repeat}.chat-wp-village{background-image:url(/wp-village.svg)}.chat-wp-social{background-image:url(/wp-social.svg)}.chat-wp-hearts{background-image:url(/wp-hearts.jpg);background-size:cover;background-position:center;background-repeat:no-repeat}.chat-wp-dark{background-image:url(/wp-dark.jpg);background-size:cover;background-position:center;background-repeat:no-repeat}.chat-messages{position:relative;z-index:1;height:100%;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px}.chat-messages.has-wallpaper{background:transparent}.loading-older{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;color:var(--text-muted);font-size:var(--font-size-sm)}.loading-older-spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.message{display:flex;align-items:flex-end;gap:8px;max-width:70%}.message.mine{align-self:flex-end;flex-direction:row-reverse}.message.other{align-self:flex-start}.message-bubble{padding:10px 14px;border-radius:18px;position:relative;min-width:0;overflow-wrap:break-word;word-break:break-word}.message.mine .message-bubble{background:var(--bg-chat-mine);border-bottom-right-radius:4px}.message.other .message-bubble{background:var(--bg-chat-other);border-bottom-left-radius:4px}.message-author{display:block;font-size:var(--font-size-xs);font-weight:600;color:var(--green-700);margin-bottom:2px}.message-text{font-size:var(--font-size-md);line-height:1.4;overflow-wrap:break-word;word-break:break-word}.message-time{font-size:10px;color:var(--text-muted);margin-left:8px;white-space:nowrap}.msg-status{color:var(--text-muted);font-weight:600;letter-spacing:-1px}.msg-status.read{color:#3b82f6}.chat-blocked-banner{display:flex;align-items:center;gap:8px;padding:14px 16px;border-top:1px solid var(--border-light);color:var(--text-muted);font-size:var(--font-size-sm);background:var(--bg-main)}.chat-blocked-banner .btn{margin-left:auto;font-size:var(--font-size-sm);color:var(--primary)}.community-contacts{max-height:220px;overflow-y:auto;border-bottom:1px solid var(--border-light)}.community-contacts .conv-info{display:flex;flex-direction:column;gap:2px}.chat-input-bar{display:flex;align-items:flex-end;gap:10px;padding:12px 16px;border-top:1px solid var(--border-light)}.chat-input-tools{display:flex;align-items:flex-end;gap:4px}.chat-input-more{display:none;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:none;background:var(--primary-light);color:var(--green-700);cursor:pointer;flex-shrink:0;align-self:center;-webkit-tap-highlight-color:transparent;transition:background .15s}.chat-input-more:active{background:var(--accent-soft)}.chat-input-wrap{flex:1;display:flex;align-items:flex-end;border:1.5px solid var(--border);border-radius:20px;transition:border-color var(--transition);overflow:hidden;min-width:0}.chat-input-wrap:focus-within{border-color:var(--border-focus)}.chat-input{flex:1;padding:10px 16px;border:none;border-radius:20px 0 0 20px;font-size:var(--font-size-md);font-family:inherit;outline:none;resize:none;line-height:1.4;max-height:80px;overflow-y:auto;scrollbar-width:thin;min-width:0}.text-size-btn{display:none}@media(max-width:768px){.text-size-btn{display:flex;align-items:center;justify-content:center;border:none;border-left:1px solid var(--border-light);border-radius:0 18px 18px 0;background:var(--bg-main);color:var(--text-muted);font-weight:700;font-size:12px;letter-spacing:-.5px;padding:0 10px;cursor:pointer;flex-shrink:0;-webkit-tap-highlight-color:transparent;transition:all .15s;align-self:stretch;line-height:1}.text-size-btn:active{background:var(--border-light)}.text-size-btn[data-level=large]{color:var(--green-600);background:var(--green-50)}.text-size-btn[data-level=xlarge]{color:var(--green-700);background:var(--green-100);font-size:13px}}.chat-send{width:42px;height:42px;border-radius:50%;padding:0;display:flex;align-items:center;justify-content:center}.emoji-picker-wrap{position:relative}.emoji-toggle{padding:6px;color:var(--text-muted);display:flex;align-items:center;justify-content:center;border-radius:50%;transition:color var(--transition)}.emoji-toggle:hover{color:var(--primary)}.emoji-picker{position:absolute;bottom:50px;left:0;width:340px;max-height:380px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:0 8px 24px #00000026;display:flex;flex-direction:column;z-index:100;overflow:hidden}.emoji-cats{display:flex;gap:2px;padding:8px 8px 4px;border-bottom:1px solid var(--border-light);overflow-x:auto}.emoji-cat-btn{background:none;border:none;font-size:18px;cursor:pointer;padding:4px 6px;border-radius:var(--radius-sm);transition:background var(--transition);flex-shrink:0}.emoji-cat-btn:hover{background:var(--bg-hover)}.emoji-cat-btn.active{background:var(--primary-light)}.emoji-cat-label{font-size:var(--font-size-xs);color:var(--text-muted);font-weight:600;padding:6px 10px 2px}.emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:2px;padding:6px;overflow-y:auto;flex:1}.emoji-btn{background:none;border:none;font-size:24px;cursor:pointer;padding:4px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;width:38px;height:38px;transition:background var(--transition)}.emoji-btn:hover{background:var(--bg-hover)}.attachments-bar{display:flex;flex-wrap:wrap;gap:8px;padding:8px 16px;border-top:1px solid var(--border-light);background:var(--bg-main);max-height:160px;overflow-y:auto}.attachment-item{display:flex;align-items:center;gap:6px;padding:4px 8px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:var(--font-size-xs);max-width:220px}.attachment-thumb{width:36px;height:36px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0}.attachment-video-thumb,.attachment-file-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-main);border-radius:var(--radius-sm);color:var(--text-muted);flex-shrink:0}.attachment-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-secondary);flex:1;min-width:0}.attachment-progress{font-size:11px;font-weight:600;color:var(--primary);white-space:nowrap;font-variant-numeric:tabular-nums;animation:pulse 1.2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.attachment-remove{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:2px;display:flex;flex-shrink:0;border-radius:50%;transition:color var(--transition)}.attachment-remove:hover{color:var(--red-600, #dc2626)}.attachment-error{color:var(--red-600, #dc2626);font-size:14px;cursor:help}.msg-image-wrap{position:relative;max-width:260px;max-height:260px;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;margin-bottom:4px}.msg-image-thumb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:blur(12px);transform:scale(1.1);z-index:1;transition:opacity .3s}.msg-image{position:relative;max-width:260px;max-height:260px;border-radius:var(--radius-md);display:block;z-index:2;opacity:0;transition:opacity .3s}.msg-image.loaded{opacity:1}.msg-image.loaded+.msg-image-thumb,.msg-image-wrap .msg-image.loaded~.msg-image-thumb{opacity:0}.msg-video{max-width:300px;max-height:260px;border-radius:var(--radius-md);display:block;margin-bottom:4px}.msg-file{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#0000000d;border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--text-secondary);text-decoration:none;margin-bottom:4px;transition:background var(--transition)}.msg-file:hover{background:#0000001a}.msg-file-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px}.lightbox{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10000;cursor:pointer}.lightbox img{max-width:90vw;max-height:90vh;border-radius:var(--radius-lg);box-shadow:0 8px 32px #00000080}.lightbox-close{position:absolute;top:20px;right:20px;background:#ffffff26;border:none;color:#fff;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.voice-recording{display:flex;align-items:center;gap:12px;flex:1}.voice-cancel{color:var(--text-muted);padding:6px}.voice-cancel:hover{color:var(--red-600, #dc2626)}.voice-rec-indicator{display:flex;align-items:center;gap:8px;flex:1}.voice-rec-dot{width:10px;height:10px;background:#dc2626;border-radius:50%;animation:pulse 1s infinite}.voice-rec-time{font-size:var(--font-size-md);font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.msg-voice{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:18px;min-width:200px}.voice-play-btn{background:none;border:none;cursor:pointer;color:var(--primary);padding:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.voice-play-btn:hover{opacity:.8}.voice-waveform{display:flex;align-items:center;gap:2px;flex:1;height:32px;cursor:pointer;padding:0 2px}.voice-bar{width:3px;border-radius:1.5px;background:var(--border);transition:background .15s;min-height:4px}.voice-bar.filled{background:var(--primary)}.voice-dur{font-size:12px;color:var(--text-muted);font-variant-numeric:tabular-nums;white-space:nowrap;min-width:28px}.msg-select-bar{display:flex;align-items:center;gap:10px;padding:8px 16px;background:var(--primary-light);border-bottom:1px solid var(--border-light)}.msg-select-count{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary);margin-right:auto}.msg-select-action{display:flex;align-items:center;gap:4px;font-size:var(--font-size-sm);padding:4px 10px;border-radius:var(--radius-md);color:var(--text-secondary)}.msg-select-action:hover{color:var(--text-primary);background:var(--bg-hover)}.msg-select-delete{color:#dc2626}.msg-select-delete:hover{color:#dc2626;background:#dc26261a}.message{cursor:pointer}.message.selected .message-bubble{outline:2px solid var(--primary);outline-offset:2px}.msg-check{width:18px;height:18px;border:2px solid var(--border);border-radius:50%;flex-shrink:0;transition:all .15s;align-self:center}.msg-check.checked{background:var(--primary);border-color:var(--primary)}.date-separator{display:flex;align-items:center;justify-content:center;padding:8px 0}.date-separator span{background:var(--bg-card);padding:4px 14px;border-radius:12px;font-size:12px;color:var(--text-secondary);font-weight:600;letter-spacing:.01em;box-shadow:0 1px 4px #0000001a;border:1px solid var(--border-light)}.has-wallpaper .date-separator span{background:#ffffffeb;color:#475569}.chat-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);gap:12px}.chat-placeholder-icon{font-size:48px}@keyframes fadeIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.msg-call{display:flex;align-items:center;gap:10px;padding:6px 0}.msg-call-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.msg-call.answered .msg-call-icon{background:#22c55e26;color:#22c55e}.msg-call.missed .msg-call-icon{background:#ef444426;color:#ef4444}.msg-call-info{display:flex;flex-direction:column;gap:1px}.msg-call-dir{font-size:14px;font-weight:500}.msg-call-status{font-size:12px;color:var(--text-muted)}.ctx-menu-overlay{position:fixed;inset:0;z-index:999}.ctx-menu{position:fixed;z-index:1000;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 4px 16px #00000026;padding:4px;min-width:140px;animation:fadeIn .12s ease-out}.ctx-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:none;border-radius:var(--radius-sm, 6px);font-size:var(--font-size-sm);cursor:pointer;color:var(--text-primary);transition:background var(--transition)}.ctx-menu-item:hover{background:var(--bg-hover)}.ctx-menu-delete{color:var(--error)}.ctx-menu-delete:hover{background:#ef44441a}.ctx-menu-report{color:var(--warning, #f59e0b)}.ctx-menu-report:hover{background:#f59e0b1a}.ctx-menu-block{color:#dc2626}.ctx-menu-block:hover{background:#dc26261a}.pinned-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-card);border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--transition)}.pinned-bar:hover{background:var(--bg-hover)}.pinned-bar-icon{color:var(--primary);flex-shrink:0}.pinned-bar-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.pinned-bar-label{font-size:var(--font-size-xs);font-weight:600;color:var(--primary)}.pinned-bar-text{font-size:var(--font-size-sm);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pinned-bar-nav{display:flex;align-items:center;gap:2px}.pinned-nav-btn{padding:2px}.pinned-bar-counter{font-size:var(--font-size-xs);color:var(--text-muted);min-width:24px;text-align:center}.pinned-close-btn{padding:4px;color:var(--text-muted)}.msg-reply-ref{display:flex;flex-direction:column;gap:1px;padding:6px 8px;margin-bottom:4px;border-left:3px solid var(--primary);border-radius:4px;background:#0000000d;cursor:pointer;font-size:var(--font-size-xs)}.msg-reply-ref-name{font-weight:600;color:var(--primary)}.msg-reply-ref-text{color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.msg-forwarded{display:flex;align-items:center;gap:4px;font-size:var(--font-size-xs);color:var(--primary);font-style:italic;margin-bottom:2px}.msg-edited{font-style:italic;color:var(--text-muted)}.msg-highlight .message-bubble{animation:msgHighlight 2s ease-out}@keyframes msgHighlight{0%,25%{box-shadow:0 0 0 2px var(--primary)}to{box-shadow:none}}.input-preview{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-card);border-top:1px solid var(--border)}.input-preview-reply .input-preview-icon{color:var(--primary)}.input-preview-edit .input-preview-icon{color:var(--warning, #f59e0b)}.input-preview-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.input-preview-label{font-size:var(--font-size-xs);font-weight:600;color:var(--primary)}.input-preview-edit .input-preview-label{color:var(--warning, #f59e0b)}.input-preview-text{font-size:var(--font-size-sm);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.input-preview-close{padding:4px;color:var(--text-muted)}.pin-confirm-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1100}.pin-confirm-dialog{background:var(--bg-card);border-radius:var(--radius-lg);padding:20px;min-width:280px;max-width:360px;box-shadow:0 8px 32px #0003}.pin-confirm-dialog h4{margin:0 0 8px}.pin-confirm-preview{font-size:var(--font-size-sm);color:var(--text-muted);margin:0 0 12px;padding:8px;background:var(--bg-hover);border-radius:var(--radius-sm)}.pin-confirm-checkbox{display:flex;align-items:center;gap:8px;font-size:var(--font-size-sm);cursor:pointer;margin-bottom:16px}.pin-confirm-checkbox input{width:16px;height:16px;accent-color:var(--primary)}.pin-confirm-actions{display:flex;justify-content:flex-end;gap:8px}.forward-modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1100}.forward-modal{background:var(--bg-card);border-radius:var(--radius-lg);padding:0;width:340px;max-width:90vw;max-height:70vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0003;overflow:hidden}.forward-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}.forward-modal-header h4{margin:0}.forward-modal-preview{padding:10px 16px;background:var(--bg-hover);font-size:var(--font-size-sm);display:flex;gap:6px}.forward-modal-from{font-weight:600;flex-shrink:0}.forward-modal-text{color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.forward-modal-list{overflow-y:auto;flex:1;padding:4px 0}.forward-conv-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;border:none;background:none;cursor:pointer;font-size:var(--font-size-sm);color:var(--text-primary);transition:background var(--transition)}.forward-conv-item:hover{background:var(--bg-hover)}.msg-link{color:var(--primary);text-decoration:underline;word-break:break-all}.msg-link:hover{color:var(--green-700)}.msg-forward-link{display:inline-flex;align-items:center;gap:6px;margin-top:6px;padding:6px 12px;border:1px solid var(--primary);border-radius:var(--radius-full);background:var(--primary-light);color:var(--green-700);font-size:var(--font-size-xs);font-weight:600;cursor:pointer;transition:all var(--transition)}.msg-forward-link:hover{background:var(--primary);color:#fff}.call-header-btn{padding:6px;color:var(--text-muted);display:flex;align-items:center;transition:color .15s}.call-header-btn:hover{color:var(--primary)}.header-more-wrap{position:relative}.header-more-btn{padding:6px;color:var(--text-muted);display:flex;align-items:center;transition:color .15s}.header-more-btn:hover{color:var(--primary)}.header-more-menu{position:absolute;top:38px;right:0;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:0 8px 24px #0000001f;padding:4px;min-width:160px;z-index:200}.header-more-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;border:none;background:none;cursor:pointer;font-size:var(--font-size-sm);color:var(--text-primary);border-radius:var(--radius-md);transition:background var(--transition);white-space:nowrap}.header-more-item:hover{background:var(--bg-hover)}.header-more-divider{height:1px;background:var(--border-light);margin:4px 8px}.official-badge{display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;background:#22c55e;border-radius:50%;width:16px;height:16px;margin-left:4px;vertical-align:middle;line-height:1}.verified-group-badge{display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;background:#3b82f6;border-radius:50%;width:16px;height:16px;margin-left:4px;vertical-align:middle;line-height:1}.verified-user-badge{display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;background:#d4a017;border-radius:50%;width:16px;height:16px;margin-left:4px;vertical-align:middle;line-height:1}.conv-members-count{display:inline-flex;align-items:center;gap:3px;font-size:11px;color:var(--text-muted);margin-left:auto;flex-shrink:0}.group-info-panel{background:var(--bg-card);border-radius:var(--radius-lg);padding:20px;width:400px;max-width:92vw;max-height:85vh;overflow-y:auto;box-shadow:0 8px 32px #0003;display:flex;flex-direction:column;gap:14px}.group-info-desc{color:var(--text-muted);font-size:var(--font-size-sm);margin:0;padding:0 4px}.group-info-section{display:flex;flex-direction:column;gap:8px}.group-info-label{display:flex;align-items:center;gap:6px;font-size:var(--font-size-sm);font-weight:600;color:var(--text-muted)}.group-invite-link{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg-page);border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:var(--font-size-sm);cursor:pointer;transition:background var(--transition)}.group-invite-link:hover{background:var(--bg-hover)}.group-invite-item{display:flex;align-items:center;gap:10px;padding:8px 0}.group-invite-name{flex:1;font-size:var(--font-size-sm)}.group-member-item{display:flex;align-items:center;gap:10px;padding:6px 0}.group-member-info{flex:1;display:flex;flex-direction:column}.group-member-name{font-size:var(--font-size-sm);font-weight:500}.group-member-role{font-size:11px;color:var(--primary);font-weight:600}.group-member-actions{display:flex;gap:2px;flex-shrink:0}.group-info-actions{padding-top:8px;border-top:1px solid var(--border-light)}.group-leave-btn{color:var(--red-500)!important;width:100%;justify-content:center;gap:8px}.support-modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1200;animation:fadeIn .15s ease-out}.support-modal{background:var(--bg-card);border-radius:var(--radius-lg);padding:20px;width:360px;max-width:92vw;box-shadow:0 8px 32px #0003;display:flex;flex-direction:column;gap:14px}.support-modal-header{display:flex;align-items:center;justify-content:space-between}.support-modal-header h4{margin:0;font-size:var(--font-size-base)}.support-cats{display:flex;flex-direction:column;gap:8px}.support-cat-btn{display:flex;align-items:center;gap:10px;width:100%;padding:12px 14px;border:1px solid var(--border-light);background:var(--bg-page);border-radius:var(--radius-md);font-size:var(--font-size-sm);cursor:pointer;color:var(--text-primary);transition:all var(--transition)}.support-cat-btn:hover{background:var(--primary-light);border-color:var(--primary)}.support-textarea{resize:vertical;min-height:80px;font-family:inherit}.support-submit{display:flex;align-items:center;justify-content:center;gap:8px}.support-success{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px 0;text-align:center;font-weight:500;color:var(--text-primary)}@media(max-width:768px){.messenger{position:fixed;top:calc(var(--header-height) + env(safe-area-inset-top,0px));left:0;right:0;bottom:calc(56px + env(safe-area-inset-bottom,0px));height:auto;border-radius:0;border:none;z-index:50}.messenger-sidebar{width:100%!important;overflow-x:hidden;display:flex!important;flex-direction:column;opacity:1!important;pointer-events:auto!important;border-right:none}.messenger-sidebar.sidebar-hidden{display:flex!important;width:100%!important;opacity:1!important;pointer-events:auto!important}.messenger-sidebar.hide-mobile,.messenger-sidebar.sidebar-hidden.hide-mobile,.sidebar-toggle-btn{display:none!important}.messenger-sidebar-header{padding:12px}.messenger-sidebar-header h2{font-size:var(--font-size-lg)}.hide-mobile{display:none!important}.mobile-back{display:flex}.messenger-contacts{display:none}.message{max-width:85%}.chat-header{padding:10px 8px;gap:6px}.chat-header-info{min-width:0}.chat-header-name{font-size:var(--font-size-sm)}.chat-header-actions{gap:0;flex-shrink:0}.call-header-btn,.header-more-btn{padding:4px}.chat-messages{padding:12px 8px}.chat-input-bar{padding:8px 6px;gap:4px}.chat-input-more{display:flex}.chat-input-tools{display:none;gap:2px}.chat-input-tools.open{display:flex}.emoji-picker{width:calc(100vw - 24px);max-width:300px;max-height:340px;left:-8px}.emoji-grid{grid-template-columns:repeat(7,1fr)}.emoji-btn{width:34px;height:34px;font-size:22px}.wp-picker{right:-8px;left:auto}.header-more-menu{right:0;min-width:140px}.attachments-bar{padding:6px 8px}.msg-voice{gap:6px}.group-info-panel{width:100%;max-width:100vw;max-height:90vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0}}.profile-cover{height:200px;background:linear-gradient(135deg,var(--green-400),var(--green-600),#065f46);border-radius:var(--radius-lg) var(--radius-lg) 0 0;position:relative}.profile-cover-gradient{position:absolute;bottom:0;left:0;right:0;height:60px;background:linear-gradient(transparent,#00000026)}.cover-change-btn{position:absolute;top:12px;right:16px;display:flex;align-items:center;gap:6px;padding:8px 16px;background:#00000080;color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;opacity:0;transition:opacity var(--transition)}.profile-cover:hover .cover-change-btn{opacity:1}.cover-change-btn:hover{background:#000000b3}.cover-crop-overlay{position:fixed;inset:0;background:var(--bg-overlay);z-index:200;display:flex;align-items:center;justify-content:center}.cover-crop-modal{background:var(--bg-card);border-radius:var(--radius-lg);width:600px;max-width:90vw;box-shadow:var(--shadow-lg);overflow:hidden}.cover-crop-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-light)}.cover-crop-header h3{font-size:var(--font-size-lg);font-weight:600}.cover-crop-preview{height:200px;overflow:hidden;background:#000}.cover-crop-preview img{width:100%;height:100%;object-fit:cover}.cover-crop-controls{display:flex;align-items:center;gap:10px;padding:16px 20px;font-size:var(--font-size-sm);color:var(--text-secondary)}.cover-crop-slider{flex:1;accent-color:var(--primary);height:4px}.cover-crop-actions{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid var(--border-light)}.profile-header{display:flex;align-items:flex-end;gap:20px;padding:0 24px 20px;margin-top:-40px;border-radius:0 0 var(--radius-lg) var(--radius-lg);position:relative}.profile-avatar-wrap{flex-shrink:0}.profile-avatar{width:100px!important;height:100px!important;font-size:32px!important;border:4px solid white;box-shadow:var(--shadow-md)}.profile-info{flex:1;padding-top:44px}.profile-name-row{display:flex;align-items:center;justify-content:space-between;gap:16px}.profile-name{font-size:22px;font-weight:700}.profile-edit-btn{font-size:var(--font-size-sm)}.profile-meta{display:flex;gap:16px;margin-top:4px;color:var(--text-secondary);font-size:var(--font-size-sm)}.profile-meta-item{display:flex;align-items:center;gap:4px}.profile-bio{margin-top:8px;color:var(--text-secondary);font-size:var(--font-size-md)}.profile-slug-link{display:inline-flex;align-items:center;gap:6px;margin-top:6px;padding:5px 12px;background:var(--bg-page);border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--text-muted);cursor:pointer;transition:all var(--transition)}.profile-slug-link:hover{background:var(--bg-hover);color:var(--text-primary)}.slug-copied-icon{color:var(--green-600)}.notif-scope-toggle{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:var(--bg-main);border:1px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm);font-weight:500;color:var(--green-700);transition:all var(--transition)}.notif-scope-toggle:hover{background:var(--primary-light);border-color:var(--green-300)}.notif-scope-toggle:disabled{opacity:.6;cursor:wait}.profile-content{display:flex;gap:16px;margin-top:16px}.profile-main{flex:1;display:flex;flex-direction:column;gap:12px}.profile-sidebar{width:260px;flex-shrink:0;display:flex;flex-direction:column;gap:12px}.profile-stats{display:flex;padding:16px;justify-content:space-around}.stat-item{display:flex;flex-direction:column;align-items:center;gap:2px}.stat-value{font-size:var(--font-size-xl);font-weight:700;color:var(--green-600)}.profile-tabs{display:flex;gap:4px;border-bottom:2px solid var(--border-light);padding-bottom:0}.profile-tab{display:flex;align-items:center;gap:6px;padding:10px 18px;font-size:var(--font-size-sm);font-weight:500;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:all var(--transition)}.profile-tab:hover{color:var(--green-700)}.profile-tab.active{color:var(--green-700);border-bottom-color:var(--primary);font-weight:600}.profile-tab-count{background:var(--primary-light);color:var(--green-700);font-size:11px;font-weight:700;padding:1px 6px;border-radius:var(--radius-full)}.profile-media-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;border-radius:var(--radius-md);overflow:hidden}.profile-media-item{aspect-ratio:1;overflow:hidden;cursor:pointer;position:relative}.profile-media-item img{width:100%;height:100%;object-fit:cover;transition:transform .2s ease}.profile-media-item:hover img{transform:scale(1.05)}.profile-media-item:after{content:"";position:absolute;inset:0;background:#0000;transition:background .2s}.profile-media-item:hover:after{background:#0000001a}.profile-lightbox{position:fixed;inset:0;background:#000000eb;z-index:300;display:flex;align-items:center;justify-content:center;cursor:pointer}.lightbox-img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:var(--radius-md);cursor:default}.lightbox-close{position:absolute;top:16px;right:16px;background:#ffffff26;border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;transition:background .2s}.lightbox-close:hover{background:#ffffff4d}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff26;border:none;border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;transition:background .2s}.lightbox-nav:hover{background:#ffffff4d}.lightbox-prev{left:16px}.lightbox-next{right:16px}.lightbox-counter{position:absolute;bottom:20px;left:50%;transform:translate(-50%);color:#ffffffb3;font-size:var(--font-size-sm);font-weight:600}.profile-posts-title{font-size:var(--font-size-lg);font-weight:600;padding:4px 0}.profile-post{padding:16px}.profile-post-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.profile-post-header .post-name{font-weight:600;font-size:var(--font-size-md);display:block}.profile-post-header .post-time{font-size:var(--font-size-xs);color:var(--text-muted)}.profile-post-content{font-size:var(--font-size-md);line-height:1.5;white-space:pre-wrap}.profile-post-stats{display:flex;gap:16px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border-light);color:var(--text-muted);font-size:var(--font-size-sm)}.profile-post-stats span{display:flex;align-items:center;gap:4px}.profile-empty{padding:40px;text-align:center;color:var(--text-muted)}.profile-info-card{padding:16px}.profile-info-card h3{font-size:var(--font-size-md);font-weight:600;margin-bottom:12px}.profile-info-row{display:flex;justify-content:space-between;padding:6px 0;font-size:var(--font-size-sm);border-bottom:1px solid var(--border-light)}.profile-info-row:last-child{border-bottom:none}.profile-info-label{color:var(--text-muted)}.profile-neighbors{display:flex;flex-wrap:wrap;gap:8px}@media(max-width:900px){.profile-content{flex-direction:column}.profile-sidebar{width:100%;order:-1}}@media(max-width:768px){.profile-cover .profile-header{flex-direction:column;align-items:center;text-align:center;padding:0 12px 16px;margin-top:-36px;gap:8px}.profile-avatar{width:80px!important;height:80px!important;font-size:26px!important}.profile-info{padding-top:0}.profile-name-row{flex-direction:column;gap:8px}.profile-name{font-size:18px}.profile-meta{justify-content:center;flex-wrap:wrap;gap:8px}.profile-bio{text-align:center}.profile-post{padding:12px}.cover-change-btn{opacity:1;padding:6px 12px;font-size:var(--font-size-xs)}.cover-crop-modal{width:95vw}.profile-media-grid{grid-template-columns:repeat(3,1fr);gap:2px}.lightbox-nav{width:36px;height:36px}.lightbox-prev{left:8px}.lightbox-next{right:8px}}.network-page{max-width:700px;margin:0 auto;display:flex;flex-direction:column;gap:16px}.network-header{display:flex;align-items:center;justify-content:center;gap:12px}.network-title{font-size:var(--font-size-xl);font-weight:700}.network-refresh{background:none;border:1px solid var(--border-light);border-radius:var(--radius-md);padding:6px 8px;cursor:pointer;color:var(--text-secondary);transition:all .15s}.network-refresh:hover{background:var(--bg-hover);color:var(--text-primary)}.network-updated{text-align:center;font-size:var(--font-size-xs);color:var(--text-muted);margin-top:-8px}.network-stats{display:flex;flex-direction:column;padding:16px 20px}.network-stat-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border-light)}.network-stat-row:last-child{border-bottom:none}.network-stat-row .stat-icon{color:var(--green-600);flex-shrink:0}.network-stat-row .stat-label{flex:1;font-size:var(--font-size-md);color:var(--text-secondary)}.network-stat-row .stat-val{font-size:var(--font-size-md);font-weight:700;color:var(--text-primary)}.network-nodes{display:flex;flex-direction:column;gap:12px}.network-node{padding:20px}.node-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border-light)}.node-status-icon.online{color:var(--success)}.node-status-icon.offline{color:var(--error)}.node-status-icon.unknown{color:var(--text-muted)}.node-title{flex:1}.node-name{font-size:var(--font-size-lg);font-weight:600}.node-ip{font-size:var(--font-size-xs);color:var(--text-muted)}.node-badge{padding:4px 12px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;white-space:nowrap}.node-badge.online{background:var(--pastel-mint);color:var(--green-700)}.node-badge.offline{background:var(--pastel-rose);color:#be123c}.node-badge.unknown{background:var(--bg-secondary);color:var(--text-muted)}.node-location{display:flex;align-items:center;gap:6px;font-size:var(--font-size-xs);color:var(--text-secondary);margin-bottom:12px}.node-details{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;text-align:center}.node-detail{display:flex;flex-direction:column;align-items:center;gap:4px}.node-detail-label{font-size:var(--font-size-xs);color:var(--text-muted)}.node-detail-value{font-size:var(--font-size-md);font-weight:600}.node-footer{display:flex;align-items:center;gap:6px;margin-top:12px;padding-top:10px;border-top:1px solid var(--border-light);font-size:var(--font-size-xs);color:var(--text-muted)}.network-alerts{padding:16px 20px}.alerts-title{display:flex;align-items:center;gap:8px;font-size:var(--font-size-md);font-weight:600;margin-bottom:12px}.alerts-list{display:flex;flex-direction:column;gap:8px}.alert-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border-light)}.alert-item:last-child{border-bottom:none}.alert-icon{font-size:14px;flex-shrink:0}.alert-body{flex:1;display:flex;flex-direction:column}.alert-node{font-size:var(--font-size-sm);font-weight:600}.alert-type{font-size:var(--font-size-xs);color:var(--text-secondary)}.alert-time{font-size:var(--font-size-xs);color:var(--text-muted);white-space:nowrap}@media(max-width:768px){.network-page{max-width:100%}.network-title{font-size:var(--font-size-lg)}.node-details{grid-template-columns:repeat(2,1fr);gap:8px}.network-node{padding:14px}.network-stats,.network-alerts{padding:12px}}.community-page{display:flex;flex-direction:column;gap:16px}.community-selector{display:flex;align-items:center;gap:10px}.community-selector-label{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);white-space:nowrap}.community-select{flex:1;max-width:320px;padding:10px 14px;border:1px solid var(--border-light);border-radius:var(--radius-md);background:var(--bg-card);font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary);cursor:pointer;transition:border-color var(--transition);appearance:auto}.community-select:focus{outline:none;border-color:var(--green-500);box-shadow:0 0 0 2px #22c55e26}.community-hero{position:relative;overflow:hidden;padding:0}.community-hero-bg{height:120px;background:linear-gradient(135deg,var(--green-400),var(--green-600),#065f46)}.community-hero-content{padding:20px 24px}.community-hero-content h1{font-size:var(--font-size-xl);font-weight:700;margin-bottom:8px}.community-meta{display:flex;gap:20px;color:var(--text-secondary);font-size:var(--font-size-sm)}.community-meta span{display:flex;align-items:center;gap:4px}.community-grid{display:flex;gap:16px}.community-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:12px}.community-sidebar{width:260px;flex-shrink:0;display:flex;flex-direction:column;gap:12px}.community-section-title{font-size:var(--font-size-lg);font-weight:600;padding-top:4px}.community-news-item{padding:16px}.community-news-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}.community-news-title{font-weight:600;font-size:var(--font-size-md)}.community-news-date{font-size:var(--font-size-xs);color:var(--text-muted)}.community-news-text{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.5}.community-event{display:flex;align-items:flex-start;gap:16px;padding:16px}.event-date-badge{width:52px;height:52px;background:var(--primary-light);border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0}.event-day{font-size:var(--font-size-lg);font-weight:700;color:var(--green-700);line-height:1}.event-month{font-size:var(--font-size-xs);color:var(--green-600);text-transform:lowercase}.event-info{display:flex;flex-direction:column;gap:3px}.event-title{font-weight:600;font-size:var(--font-size-md)}.event-desc{font-size:var(--font-size-sm);color:var(--text-secondary)}.event-meta{font-size:var(--font-size-xs);color:var(--text-muted);display:flex;align-items:center;gap:4px}.community-residents{padding:16px}.community-residents h3{font-size:var(--font-size-md);font-weight:600;margin-bottom:12px;display:flex;align-items:center;gap:8px}.residents-count{font-size:var(--font-size-xs);background:var(--primary-light);color:var(--green-700);padding:1px 8px;border-radius:var(--radius-full);font-weight:600}.residents-list{display:flex;flex-direction:column;gap:6px}.resident-item{display:flex;align-items:center;gap:10px;padding:4px 0}.resident-avatar-wrap{position:relative;flex-shrink:0}.resident-info{display:flex;flex-direction:column}.resident-role{font-size:var(--font-size-xs);color:var(--text-muted)}.verified-badge{color:var(--green-600);margin-left:4px;vertical-align:middle;flex-shrink:0}.resident-name{font-size:var(--font-size-sm);font-weight:500;display:flex;align-items:center;gap:2px}.verify-btn{margin-left:auto;background:none;border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:4px 6px;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;transition:all .15s}.verify-btn:hover{border-color:var(--green-500);color:var(--green-600)}.verify-btn.verified{color:var(--green-600);border-color:var(--green-500);background:var(--primary-light)}.community-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.stat-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 8px;color:var(--green-600)}.stat-value{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary)}.stat-label{font-size:var(--font-size-xs);color:var(--text-muted)}.community-posts{display:flex;flex-direction:column;gap:8px}.community-post-card{padding:14px 16px}.community-post-header{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:var(--font-size-sm)}.community-post-header strong{font-weight:600}.post-type-tag{font-size:var(--font-size-xs);padding:1px 8px;border-radius:var(--radius-full);font-weight:500}.post-type-tag.event{background:#dbeafe;color:#1d4ed8}.post-type-tag.announcement{background:#fef3c7;color:#92400e}.community-post-date{margin-left:auto;color:var(--text-muted);font-size:var(--font-size-xs)}.community-post-text{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.5}.community-info-card{padding:16px}.community-info-card h3{font-size:var(--font-size-md);font-weight:600;margin-bottom:12px}.community-info-row{display:flex;justify-content:space-between;padding:6px 0;font-size:var(--font-size-sm);border-bottom:1px solid var(--border-light)}.community-info-row:last-child{border-bottom:none}.community-info-label{color:var(--text-muted)}@media(max-width:768px){.community-grid{flex-direction:column}.community-sidebar{width:100%}.community-hero-bg{height:80px}.community-hero-content{padding:14px 16px}.community-hero-content h1{font-size:var(--font-size-lg)}.community-meta{gap:12px;flex-wrap:wrap}.community-event{padding:12px;gap:10px}.community-news-item,.community-residents,.community-info-card{padding:12px}.community-stats{grid-template-columns:repeat(2,1fr)}.stat-card{padding:12px 6px}}.classifieds-page{display:flex;flex-direction:column;gap:12px}.classifieds-header{display:flex;justify-content:space-between;align-items:center}.classifieds-header h1{font-size:var(--font-size-xl);font-weight:700}.classifieds-search{display:flex;align-items:center;gap:10px;padding:10px 16px}.classifieds-search-icon{color:var(--text-muted);flex-shrink:0}.classifieds-search input{border:none;outline:none;background:transparent;font-size:var(--font-size-md);width:100%;color:var(--text-primary)}.classifieds-categories{display:flex;gap:8px;flex-wrap:wrap}.category-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border:1px solid var(--border);border-radius:var(--radius-full);background:var(--bg-card);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition);color:var(--text-secondary)}.category-btn:hover{border-color:var(--primary);color:var(--green-700)}.category-btn.active{background:var(--primary-light);border-color:var(--primary);color:var(--green-700);font-weight:600}.classified-form{display:flex;flex-direction:column;gap:10px;padding:16px}.classified-textarea{resize:vertical;min-height:60px;font-family:inherit}.classified-form-row{display:flex;gap:10px}.classified-form-row .input{flex:1}.classifieds-list{display:flex;flex-direction:column;gap:12px}.classifieds-empty{padding:40px;text-align:center;color:var(--text-muted)}.classified-item{padding:16px}.classified-top{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}.classified-author{display:flex;align-items:center;gap:10px}.classified-author-name{font-weight:600;font-size:var(--font-size-sm)}.classified-time{font-size:var(--font-size-xs);color:var(--text-muted)}.classified-hot{font-size:var(--font-size-xs);font-weight:600;background:var(--pastel-peach);color:#92400e;padding:3px 10px;border-radius:var(--radius-full)}.classified-body{margin-bottom:12px}.classified-title{font-size:var(--font-size-md);font-weight:600;margin-bottom:4px}.classified-text{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.5}.classified-footer{display:flex;align-items:center;gap:12px;padding-top:12px;border-top:1px solid var(--border-light)}.classified-price{font-size:var(--font-size-md);font-weight:700;color:var(--green-700)}.classified-category-tag{font-size:var(--font-size-xs);color:var(--text-muted);white-space:nowrap}.classified-contact{margin-left:auto;font-size:var(--font-size-sm);padding:5px 14px}.cl-form-previews{display:flex;gap:8px;flex-wrap:wrap}.cl-form-thumb{position:relative;width:72px;height:72px;border-radius:var(--radius-md);overflow:hidden}.cl-form-thumb img{width:100%;height:100%;object-fit:cover}.cl-form-thumb-rm{position:absolute;top:2px;right:2px;width:22px;height:22px;border-radius:50%;background:#0009;color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer}.cl-form-video-preview{position:relative;border-radius:var(--radius-md);overflow:hidden}.cl-form-video-preview video{width:100%;max-height:200px;border-radius:var(--radius-md)}.cl-gallery{display:grid;gap:4px;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:12px}.cl-gallery-1{grid-template-columns:1fr}.cl-gallery-2,.cl-gallery-3{grid-template-columns:1fr 1fr}.cl-gallery-3 .cl-gallery-cell:first-child{grid-row:span 2}.cl-gallery-4{grid-template-columns:1fr 1fr}.cl-gallery-cell{position:relative;cursor:pointer;overflow:hidden}.cl-gallery-cell img{width:100%;height:200px;object-fit:cover;display:block;transition:transform .2s}.cl-gallery-cell:hover img{transform:scale(1.03)}.cl-gallery-1 .cl-gallery-cell img{height:300px}.cl-gallery-more{position:absolute;inset:0;background:#00000080;color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700}.cl-video{margin-bottom:12px;border-radius:var(--radius-lg);overflow:hidden}.cl-video video{width:100%;max-height:400px;display:block;background:#000}.cl-stats{display:flex;gap:16px;padding:6px 0;font-size:var(--font-size-sm);color:var(--text-secondary)}.cl-actions{display:flex;border-top:1px solid var(--border-light);padding-top:8px}.cl-action{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:8px;border:none;background:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition)}.cl-action:hover{background:var(--bg-hover);color:var(--text-primary)}.cl-action.liked{color:var(--error)}.cl-action.active{color:var(--primary);background:var(--primary-light)}.cl-action.shared{color:var(--green-700)}.cl-comments{padding:12px 0 0;border-top:1px solid var(--border-light)}.cl-comments-empty{text-align:center;color:var(--text-muted);font-size:var(--font-size-sm);padding:8px 0;margin:0}.cl-comment{display:flex;gap:10px;padding:8px 0}.cl-comment-reply{margin-left:32px}.cl-comment-body{display:flex;flex-direction:column;gap:2px;flex:1}.cl-comment-author{font-weight:600;font-size:var(--font-size-sm)}.cl-comment-reply-to{font-size:var(--font-size-xs);color:var(--primary);display:flex;align-items:center;gap:4px}.cl-comment-text{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.4}.cl-comment-footer{display:flex;align-items:center;gap:12px;margin-top:2px}.cl-comment-time{font-size:var(--font-size-xs);color:var(--text-muted)}.cl-comment-act{display:flex;align-items:center;gap:3px;border:none;background:none;padding:0;font-size:var(--font-size-xs);color:var(--text-muted);cursor:pointer;transition:color var(--transition)}.cl-comment-act:hover{color:var(--text-primary)}.cl-comment-act.liked{color:var(--error)}.cl-reply-bar{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;background:var(--primary-light);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--primary);margin-bottom:4px}.cl-reply-cancel{border:none;background:none;color:var(--text-muted);cursor:pointer;padding:2px;display:flex}.cl-comment-input-row{display:flex;align-items:center;gap:10px;padding-top:8px;border-top:1px solid var(--border-light);margin-top:4px}.cl-comment-input{flex:1;border:1px solid var(--border);border-radius:var(--radius-full);padding:8px 14px;font-size:var(--font-size-sm);background:var(--bg-input);color:var(--text-primary);outline:none}.cl-comment-input:focus{border-color:var(--primary)}.cl-lightbox{position:fixed;inset:0;background:#000000eb;z-index:2000;display:flex;align-items:center;justify-content:center}.cl-lb-img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:var(--radius-md);-webkit-user-select:none;user-select:none}.cl-lb-close{position:absolute;top:16px;right:16px;background:none;border:none;color:#fff;cursor:pointer;z-index:2001}.cl-lb-prev,.cl-lb-next{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff26;border:none;color:#fff;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background .2s}.cl-lb-prev:hover,.cl-lb-next:hover{background:#ffffff4d}.cl-lb-prev{left:16px}.cl-lb-next{right:16px}.cl-lb-counter{position:absolute;bottom:20px;left:50%;transform:translate(-50%);color:#ffffffb3;font-size:var(--font-size-sm)}@media(max-width:768px){.classifieds-header{flex-direction:column;align-items:stretch;gap:10px}.classifieds-header h1{font-size:var(--font-size-lg)}.classifieds-categories{gap:6px}.category-btn{padding:5px 10px;font-size:var(--font-size-xs)}.classified-form{padding:12px}.classified-form-row{flex-wrap:wrap}.classified-form-row .input{min-width:0}.classified-form-row .btn{font-size:var(--font-size-xs);padding:6px 10px}.classified-item{padding:12px}.classified-top{flex-wrap:wrap;gap:6px}.classified-footer{flex-wrap:wrap;gap:8px}.classified-contact{margin-left:0;width:100%;text-align:center}.cl-actions{flex-wrap:wrap}.cl-action{font-size:var(--font-size-xs);padding:6px;gap:3px;min-width:0}.cl-comment-input-row{flex-wrap:wrap;gap:8px}.cl-comment-input{min-width:0}.cl-gallery-cell img{height:150px}.cl-lb-prev,.cl-lb-next{width:36px;height:36px}}.admin-page{display:flex;flex-direction:column;gap:16px}.admin-header{display:flex;align-items:center;gap:10px;color:var(--green-700)}.admin-header h1{font-size:var(--font-size-xl);font-weight:700}.admin-tabs{display:flex;gap:6px;flex-wrap:wrap}.admin-tab{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--border);border-radius:var(--radius-full);background:var(--bg-card);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;color:var(--text-secondary);transition:all var(--transition)}.admin-tab:hover{border-color:var(--primary);color:var(--green-700)}.admin-tab.active{background:var(--primary-light);border-color:var(--primary);color:var(--green-700);font-weight:600}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.admin-stat-card{padding:20px;text-align:center}.admin-stat-value{font-size:32px;font-weight:800;line-height:1}.admin-stat-label{font-size:var(--font-size-sm);color:var(--text-muted);margin-top:6px}.admin-users-list{display:flex;flex-direction:column;gap:8px}.admin-user-row{display:flex;align-items:center;gap:16px;padding:14px 16px}.admin-user-info{display:flex;align-items:center;gap:10px;min-width:200px}.admin-user-name{font-weight:600;font-size:var(--font-size-md)}.admin-user-email{font-size:var(--font-size-xs);color:var(--text-muted)}.admin-user-meta{flex:1;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.admin-user-date{font-size:var(--font-size-xs);color:var(--text-muted)}.admin-user-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.admin-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;white-space:nowrap}.admin-badge-green{background:var(--pastel-mint);color:var(--green-700)}.admin-badge-gray{background:var(--bg-secondary);color:var(--text-muted)}.admin-badge-red{background:var(--pastel-rose);color:#be123c}.admin-select{padding:5px 10px;border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--bg-card);color:var(--text-primary);cursor:pointer}.btn-danger{background:#fee2e2;color:#dc2626;border:1px solid #fecaca}.btn-danger:hover{background:#fecaca}.btn-sm{padding:4px 10px;font-size:var(--font-size-xs)}.admin-feedback-list{display:flex;flex-direction:column;gap:10px}.admin-feedback-item{padding:16px}.admin-feedback-item.new{border-left:3px solid #dc2626}.admin-feedback-item.resolved{opacity:.7}.admin-feedback-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.admin-feedback-msg{font-size:var(--font-size-md);color:var(--text-secondary);line-height:1.5;margin-bottom:10px}.admin-feedback-footer{display:flex;align-items:center;gap:12px;font-size:var(--font-size-xs);color:var(--text-muted);flex-wrap:wrap}.admin-feedback-actions{margin-left:auto;display:flex;gap:6px}.admin-empty{padding:40px;text-align:center;color:var(--text-muted)}.srv-live-dot{display:flex;align-items:center;gap:6px;font-size:var(--font-size-xs);color:#22c55e;animation:srv-pulse 2s ease infinite}@keyframes srv-pulse{0%,to{opacity:1}50%{opacity:.4}}.srv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.srv-card{padding:16px}.srv-card-head{display:flex;align-items:center;gap:6px;font-weight:700;font-size:var(--font-size-sm);margin-bottom:10px;color:var(--text-primary)}.srv-bar-wrap{height:8px;background:var(--bg-secondary);border-radius:4px;overflow:hidden;margin-bottom:6px}.srv-bar{height:100%;border-radius:4px;transition:width .5s ease}.srv-bar-label{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary)}.srv-detail{font-size:var(--font-size-xs);color:var(--text-muted);margin-top:2px}.srv-small{font-size:11px;word-break:break-all}.srv-big-value{font-size:28px;font-weight:800;line-height:1.2;color:var(--text-primary);margin-bottom:2px}.srv-section{padding:16px;margin-top:4px}.srv-section-head{display:flex;align-items:center;gap:6px;font-weight:700;font-size:var(--font-size-sm);margin-bottom:12px;color:var(--text-primary)}.srv-disk-row{display:flex;align-items:center;gap:10px;padding:6px 0}.srv-disk-row+.srv-disk-row{border-top:1px solid var(--border)}.srv-disk-mount{min-width:80px;font-size:var(--font-size-xs);font-weight:600;color:var(--text-primary);font-family:monospace}.srv-bar-inline{flex:1;margin-bottom:0}.srv-disk-info{min-width:140px;text-align:right;font-size:var(--font-size-xs);color:var(--text-muted)}.srv-containers{display:flex;flex-direction:column;gap:6px}.srv-container{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius-md);background:var(--bg-secondary);font-size:var(--font-size-sm)}.srv-ct-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.srv-ct-dot.running{background:#22c55e}.srv-ct-dot.exited{background:#ef4444}.srv-ct-dot.created,.srv-ct-dot.restarting{background:#f59e0b}.srv-ct-name{font-weight:600;min-width:100px}.srv-ct-status{flex:1;color:var(--text-muted);font-size:var(--font-size-xs)}.srv-ct-image{color:var(--text-muted);font-size:var(--font-size-xs);font-family:monospace}.srv-health{display:flex;align-items:center;gap:20px;padding:16px 20px}.srv-health-gauge{position:relative;width:120px;flex-shrink:0;text-align:center}.srv-gauge-svg{width:100%}.srv-gauge-value{font-size:28px;font-weight:800;margin-top:-24px}.srv-gauge-label{font-size:var(--font-size-xs);color:var(--text-muted);font-weight:600}.srv-health-recs{flex:1;display:flex;flex-direction:column;gap:4px}.srv-rec{font-size:var(--font-size-sm);line-height:1.4}.srv-active-users{display:flex;flex-direction:column;gap:6px}.srv-au-row{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius-md);background:var(--bg-secondary);font-size:var(--font-size-sm)}.srv-au-row.srv-au-spam{background:#fef2f2;border:1px solid #fecaca}.srv-au-user{display:flex;align-items:center;gap:8px;min-width:160px}.srv-au-name{font-weight:600}.srv-au-stats{flex:1;display:flex;align-items:center;gap:12px}.srv-au-rpm{display:inline-flex;align-items:center;gap:3px;font-weight:700;padding:2px 8px;border-radius:var(--radius-full);background:var(--pastel-mint);color:var(--green-700);font-size:var(--font-size-xs)}.srv-au-rpm.srv-au-warn{background:#fef3c7;color:#92400e}.srv-au-rpm.srv-au-danger{background:#fee2e2;color:#dc2626;animation:srv-pulse 1s infinite}.srv-au-total{font-size:var(--font-size-xs);color:var(--text-muted)}.srv-au-ip{font-size:var(--font-size-xs);color:var(--text-muted);font-family:monospace}.srv-au-actions{flex-shrink:0}.admin-support{display:flex;flex-direction:column;gap:10px}.admin-support-filters{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:4px}.admin-ticket{padding:16px;display:flex;flex-direction:column;gap:8px}.admin-ticket-open{border-left:3px solid #dc2626}.admin-ticket-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.admin-ticket-title{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.admin-ticket-date{font-size:var(--font-size-xs);color:var(--text-muted);white-space:nowrap}.admin-ticket-user{font-size:var(--font-size-sm);color:var(--text-muted)}.admin-ticket-reported{color:#dc2626;font-weight:600}.admin-ticket-msg{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.5;padding:8px 12px;background:var(--bg-secondary);border-radius:var(--radius-md);white-space:pre-wrap}.admin-ticket-actions{display:flex;align-items:center;gap:8px}.admin-ticket-reply{display:flex;flex-direction:column;gap:8px;padding-top:8px;border-top:1px solid var(--border)}.admin-ticket-textarea{resize:vertical;min-height:60px;font-family:inherit}.admin-quick-replies{display:flex;flex-wrap:wrap;gap:6px}.admin-qr-btn{padding:4px 10px;border:1px solid var(--border-light);border-radius:var(--radius-full);background:var(--bg-page);font-size:var(--font-size-xs);color:var(--text-secondary);cursor:pointer;transition:all var(--transition)}.admin-qr-btn:hover{background:var(--primary-light);border-color:var(--primary);color:var(--green-700)}.admin-ticket-messages{display:flex;flex-direction:column;gap:8px;padding:10px;background:var(--bg-secondary);border-radius:var(--radius-md);max-height:400px;overflow-y:auto}.admin-tmsg{padding:8px 12px;border-radius:var(--radius-md);max-width:85%}.admin-tmsg-user{background:var(--bg-card);align-self:flex-start;border:1px solid var(--border-light)}.admin-tmsg-system{background:var(--primary-light);align-self:flex-end}.admin-tmsg-header{display:flex;align-items:baseline;gap:8px;margin-bottom:4px;font-size:var(--font-size-xs)}.admin-tmsg-header strong{font-size:var(--font-size-sm)}.admin-tmsg-time{color:var(--text-muted);font-size:11px}.admin-tmsg-text{font-size:var(--font-size-sm);line-height:1.4;white-space:pre-wrap;word-break:break-word}.admin-tmsg-img-wrap{display:block;margin-top:4px}.admin-tmsg-img{max-width:280px;max-height:200px;border-radius:var(--radius-md);object-fit:cover;cursor:pointer}.admin-tmsg-file{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:var(--bg-secondary);border-radius:var(--radius-md);font-size:var(--font-size-xs);color:var(--primary);text-decoration:none;margin-top:4px}.admin-tmsg-file:hover{background:var(--bg-hover)}@media(max-width:768px){.admin-user-row{flex-direction:column;align-items:flex-start;gap:8px}.admin-user-info{min-width:auto}.admin-user-actions{width:100%}.admin-stats-grid{grid-template-columns:repeat(2,1fr)}.admin-stat-value{font-size:24px}.admin-feedback-footer{flex-direction:column;align-items:flex-start}.admin-feedback-actions{margin-left:0}.srv-grid{grid-template-columns:1fr 1fr}.srv-big-value{font-size:22px}.srv-disk-row{flex-wrap:wrap}.srv-disk-info{min-width:auto;text-align:left}.srv-container{flex-wrap:wrap}.srv-ct-name{min-width:auto}.srv-health{flex-direction:column;text-align:center}.srv-health-gauge{width:100px}.srv-au-row{flex-wrap:wrap}.srv-au-user{min-width:auto}.srv-au-stats{flex-wrap:wrap;gap:6px}}@media(max-width:480px){.srv-grid{grid-template-columns:1fr}}.search-page{max-width:680px;margin:0 auto;display:flex;flex-direction:column;gap:16px}.search-header-card{display:flex;align-items:center;gap:10px;color:var(--text-secondary)}.search-header-card strong{color:var(--text-primary)}.search-count{margin-left:auto;font-size:14px;color:var(--text-muted)}.search-loading,.search-empty{text-align:center;color:var(--text-muted);padding:32px 16px}.search-section{display:flex;flex-direction:column;gap:8px}.search-section-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:var(--text-secondary);margin:0}.search-user-card{display:flex;align-items:center;gap:12px}.search-user-name{flex:1;font-weight:500}.btn-sm{font-size:13px;padding:6px 12px;gap:4px}.btn-outline{background:transparent;border:1px solid var(--primary);color:var(--primary)}.btn-outline:hover{background:var(--primary);color:#fff}.search-post-card,.search-classified-card{display:flex;flex-direction:column;gap:6px}.search-post-meta{display:flex;align-items:center;gap:8px}.search-time{font-size:13px;color:var(--text-muted)}.search-post-text{margin:0;color:var(--text-secondary);font-size:14px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.search-classified-top{display:flex;align-items:center;justify-content:space-between}.search-price{font-weight:600;color:var(--primary)}@media(max-width:768px){.search-page{padding:0 8px}}.vr-room{position:fixed;inset:0;background:#111;display:flex;flex-direction:column;z-index:1000;color:#fff}.vr-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2}.vr-room-name{font-size:16px;font-weight:600}.vr-room-info{display:flex;align-items:center;gap:8px;font-size:13px;color:#aaa}.vr-timer{font-variant-numeric:tabular-nums}.vr-invite-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;border:1px solid rgba(255,255,255,.2);background:#ffffff1a;color:#fff;font-size:13px;cursor:pointer;transition:background .2s}.vr-invite-btn:hover{background:#fff3}.vr-invite-btn.copied{border-color:#22c55e;color:#22c55e}.vr-grid{flex:1;display:grid;gap:8px;padding:8px;overflow:hidden}.vr-grid[data-count="1"]{grid-template-columns:1fr;grid-template-rows:1fr}.vr-grid[data-count="2"]{grid-template-columns:1fr 1fr;grid-template-rows:1fr}.vr-grid[data-count="3"]{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.vr-grid[data-count="3"] .vr-video-cell:first-child{grid-column:1 / -1}.vr-grid[data-count="4"]{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.vr-grid[data-count="5"],.vr-grid[data-count="6"]{grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr}.vr-grid[data-count="7"],.vr-grid[data-count="8"],.vr-grid[data-count="9"]{grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr 1fr}.vr-video-cell{position:relative;background:#222;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center}.vr-video-cell video{width:100%;height:100%;object-fit:cover;border-radius:12px}.vr-video-cell.local video{transform:scaleX(-1)}.vr-video-label{position:absolute;bottom:8px;left:8px;display:flex;align-items:center;gap:6px;padding:4px 10px;background:#0009;border-radius:16px;font-size:12px;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.vr-video-label .avatar{width:22px;height:22px;font-size:9px;line-height:22px}.vr-video-muted-icon{color:#ef4444}.vr-no-video{display:flex;flex-direction:column;align-items:center;gap:8px;color:#888}.vr-no-video .avatar{width:80px;height:80px;font-size:28px;line-height:80px}.vr-no-video-name{font-size:14px;color:#ccc}.vr-controls{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px 20px;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.vr-ctrl-btn{display:flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:50%;border:none;cursor:pointer;transition:all .2s;color:#fff;background:#ffffff26}.vr-ctrl-btn:hover{background:#ffffff40}.vr-ctrl-btn.active{background:#ef4444}.vr-ctrl-btn.leave{background:#ef4444;width:64px;height:52px;border-radius:28px}.vr-ctrl-btn.leave:hover{background:#dc2626}.vr-lobby{position:fixed;inset:0;background:#111;display:flex;align-items:center;justify-content:center;z-index:1000;color:#fff}.vr-lobby-card{text-align:center;max-width:400px;padding:40px}.vr-lobby-title{font-size:24px;font-weight:700;margin-bottom:8px}.vr-lobby-sub{color:#888;font-size:14px;margin-bottom:24px}.vr-lobby-preview{width:320px;height:240px;background:#222;border-radius:16px;overflow:hidden;margin:0 auto 24px;display:flex;align-items:center;justify-content:center}.vr-lobby-preview video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1);border-radius:16px}.vr-lobby-controls{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:24px}.vr-lobby-join{display:inline-flex;align-items:center;gap:8px;padding:12px 32px;border-radius:24px;border:none;background:#22c55e;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s}.vr-lobby-join:hover{background:#16a34a}.vr-lobby-join:disabled{opacity:.5;cursor:not-allowed}.vr-lobby-back{display:inline-flex;align-items:center;gap:6px;margin-top:16px;color:#888;font-size:14px;cursor:pointer;background:none;border:none}.vr-lobby-back:hover{color:#ccc}@media(max-width:768px){.vr-grid[data-count="2"]{grid-template-columns:1fr;grid-template-rows:1fr 1fr}.vr-grid[data-count="3"],.vr-grid[data-count="4"]{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.vr-grid[data-count="3"] .vr-video-cell:first-child{grid-column:auto}.vr-grid[data-count="5"],.vr-grid[data-count="6"],.vr-grid[data-count="7"],.vr-grid[data-count="8"],.vr-grid[data-count="9"]{grid-template-columns:1fr 1fr}.vr-header{padding:8px 12px}.vr-controls{padding:12px;gap:10px}.vr-ctrl-btn{width:46px;height:46px}.vr-ctrl-btn.leave{width:56px;height:46px}.vr-lobby-preview{width:260px;height:195px}}:root{--green-50: #f0fdf4;--green-100: #dcfce7;--green-200: #bbf7d0;--green-300: #86efac;--green-400: #4ade80;--green-500: #22c55e;--green-600: #16a34a;--green-700: #15803d;--pastel-mint: #d1fae5;--pastel-lime: #ecfccb;--pastel-sky: #e0f2fe;--pastel-lavender:#ede9fe;--pastel-peach: #fef3c7;--pastel-rose: #ffe4e6;--pastel-cream: #fefce8;--primary: #4ade80;--primary-hover: #22c55e;--primary-light: #dcfce7;--primary-bg: #f0fdf4;--accent: #86efac;--accent-soft: #bbf7d0;--success: #22c55e;--warning: #f59e0b;--error: #ef4444;--info: #3b82f6;--bg-main: #f8fdf9;--bg-sidebar: #ffffff;--bg-card: #ffffff;--bg-hover: #f0fdf4;--bg-input: #ffffff;--bg-chat-mine: #dcfce7;--bg-chat-other: #f1f5f9;--bg-overlay: rgba(0, 0, 0, .4);--text-primary: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--text-inverse: #ffffff;--text-link: #16a34a;--border: #e2e8f0;--border-light: #f1f5f9;--border-focus: #4ade80;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -4px rgba(0, 0, 0, .05);--shadow-glow: 0 0 20px rgba(74, 222, 128, .15);--sidebar-width: 200px;--header-height: 56px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-full: 9999px;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: 12px;--font-size-sm: 13px;--font-size-md: 14px;--font-size-lg: 16px;--font-size-xl: 20px;--font-size-2xl: 24px;--transition: .2s ease;--transition-slow: .3s ease}html[data-text-size=large]{--font-size-xs: 14px;--font-size-sm: 15px;--font-size-md: 16px;--font-size-lg: 18px;--font-size-xl: 22px;--font-size-2xl: 28px}html[data-text-size=xlarge]{--font-size-xs: 16px;--font-size-sm: 18px;--font-size-md: 19px;--font-size-lg: 21px;--font-size-xl: 25px;--font-size-2xl: 32px}*{margin:0;padding:0;box-sizing:border-box}html{overflow-y:scroll;overflow-x:hidden}body{font-family:var(--font-family);font-size:var(--font-size-md);color:var(--text-primary);background:var(--bg-main);line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden;-webkit-text-size-adjust:100%}a{color:var(--text-link);text-decoration:none}a:hover{text-decoration:underline}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:var(--radius-md);font-size:var(--font-size-md);font-weight:500;cursor:pointer;transition:all var(--transition)}.btn-primary{background:var(--primary);color:var(--text-inverse)}.btn-primary:hover{background:var(--primary-hover);box-shadow:var(--shadow-glow)}.btn-secondary{background:var(--primary-light);color:var(--green-700)}.btn-secondary:hover{background:var(--accent-soft)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.input{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-md);font-size:var(--font-size-md);background:var(--bg-input);color:var(--text-primary);transition:border-color var(--transition);outline:none}.input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #4ade8026}.input::placeholder{color:var(--text-muted)}.card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-light);box-shadow:var(--shadow-sm)}.avatar{width:40px;height:40px;border-radius:var(--radius-full);object-fit:cover;background:var(--pastel-mint);display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--green-700);font-size:var(--font-size-sm);flex-shrink:0}.avatar-sm{width:32px;height:32px;font-size:11px}.avatar-lg{width:56px;height:56px;font-size:var(--font-size-lg)}.avatar-xl{width:80px;height:80px;font-size:var(--font-size-xl)}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600}.badge-green{background:var(--pastel-mint);color:var(--green-700)}.badge-sky{background:var(--pastel-sky);color:#0369a1}.badge-peach{background:var(--pastel-peach);color:#92400e}.badge-rose{background:var(--pastel-rose);color:#be123c}.online-dot{width:10px;height:10px;border-radius:50%;background:var(--success);border:2px solid white;position:absolute;bottom:0;right:0}@media(max-width:768px){input,textarea,select{font-size:16px!important}*{-webkit-tap-highlight-color:transparent}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}
