@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap);:root[data-theme=dark]{--bg-primary:#111b21;--bg-secondary:#202c33;--bg-tertiary:#2a3942;--bg-hover:#2a3942;--bg-input:#2a3942;--bg-message-out:#005c4b;--bg-message-in:#202c33;--bg-card:#1f2c34;--bg-panel:#111b21;--text-primary:#e9edef;--text-secondary:#8696a0;--text-tertiary:#667781;--text-link:#53bdeb;--accent:#00a884;--accent-hover:#06cf9c;--accent-light:#0d3b2e;--border:#2a3942;--border-light:#1f2c34;--shadow:0 4px 24px rgba(0,0,0,.5);--shadow-sm:0 1px 6px rgba(0,0,0,.3);--scrollbar-thumb:#374045;--online:#06cf9c;--offline:#8696a0;--bg-active:#2a3942}:root[data-theme=light]{--bg-primary:#f0f2f5;--bg-secondary:#fff;--bg-tertiary:#f0f2f5;--bg-hover:#f5f6f6;--bg-input:#fff;--bg-message-out:#d9fdd3;--bg-message-in:#fff;--bg-card:#fff;--bg-panel:#f0f2f5;--text-primary:#111b21;--text-secondary:#667781;--text-tertiary:#8696a0;--text-link:#027eb5;--accent:#00a884;--accent-hover:#008f72;--accent-light:#e7f8f0;--border:#e9edef;--border-light:#f0f2f5;--shadow:0 4px 24px rgba(0,0,0,.12);--shadow-sm:0 1px 6px rgba(0,0,0,.08);--scrollbar-thumb:#c4ccd2;--online:#00a884;--offline:#8696a0;--bg-active:#e7f8f0}*,:after,:before{box-sizing:border-box;margin:0;padding:0}#root,body,html{-webkit-font-smoothing:antialiased;background:var(--bg-primary);color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;height:100%;overflow:hidden;transition:background .25s,color .25s;width:100%}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}@-webkit-keyframes typingDot{0%,60%,to{-webkit-transform:translateY(0);transform:translateY(0)}30%{-webkit-transform:translateY(-6px);transform:translateY(-6px)}}@keyframes typingDot{0%,60%,to{-webkit-transform:translateY(0);transform:translateY(0)}30%{-webkit-transform:translateY(-6px);transform:translateY(-6px)}}@-webkit-keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.fade-in{-webkit-animation:fadeIn .3s ease forwards;animation:fadeIn .3s ease forwards}.slide-left{-webkit-animation:slideInLeft .25s ease forwards;animation:slideInLeft .25s ease forwards}.slide-right{-webkit-animation:slideInRight .25s ease forwards;animation:slideInRight .25s ease forwards}.scale-in{-webkit-animation:scaleIn .25s ease forwards;animation:scaleIn .25s ease forwards}.handy{cursor:pointer}.typing-dot{-webkit-animation:typingDot 1.2s infinite;animation:typingDot 1.2s infinite;background:var(--text-secondary);display:inline-block;height:7px;width:7px}.skeleton{-webkit-animation:shimmer 1.5s infinite;animation:shimmer 1.5s infinite;background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-hover) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;border-radius:8px}.btn{font-family:inherit}a{color:inherit}.app-layout{flex-direction:column;height:100vh;width:100vw}.app-body,.app-layout{display:flex;overflow:hidden}.app-body{flex:1 1;min-height:0}.app-body>*{height:100%;width:100%}.navbar-pro{background:var(--bg-secondary);border-bottom:1px solid var(--border);gap:1rem;height:56px;min-height:56px;padding:0 1.25rem;position:-webkit-sticky;position:sticky;top:0;transition:background .25s,border-color .25s;z-index:900}.navbar-brand-pro,.navbar-pro{align-items:center;display:flex}.navbar-brand-pro{gap:.5rem;min-width:120px;text-decoration:none}.brand-dot{background:var(--accent);border-radius:50%;box-shadow:0 0 8px var(--accent);flex-shrink:0;height:10px;width:10px}.brand-name{color:var(--text-primary);font-size:1.15rem;font-weight:700;letter-spacing:-.3px}.navbar-links-pro{align-items:center;display:flex;flex:1 1;gap:.25rem;justify-content:center}.nav-link-pro{align-items:center;border-radius:8px;color:var(--text-secondary);display:flex;font-size:.875rem;font-weight:500;gap:.4rem;padding:.45rem .85rem;position:relative;text-decoration:none;transition:color .18s,background .18s}.nav-link-pro:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-link-pro.active{background:var(--accent-light);color:var(--accent)}.nav-link-pro.active:after{background:var(--accent);border-radius:2px 2px 0 0;bottom:-1px;content:"";height:2px;left:50%;position:absolute;-webkit-transform:translateX(-50%);transform:translateX(-50%);width:20px}.nav-icon{align-items:center;display:flex;font-size:1.2rem}.nav-label{font-size:.83rem}.navbar-actions-pro{align-items:center;display:flex;gap:.5rem;justify-content:flex-end;min-width:120px}.theme-toggle{align-items:center;background:var(--bg-tertiary);border:none;border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;font-size:1.1rem;height:36px;justify-content:center;transition:background .18s,color .18s,-webkit-transform .18s;transition:background .18s,color .18s,transform .18s;transition:background .18s,color .18s,transform .18s,-webkit-transform .18s;width:36px}.theme-toggle:hover{background:var(--bg-hover);color:var(--accent);-webkit-transform:rotate(20deg);transform:rotate(20deg)}.btn-nav-auth{align-items:center;background:transparent;border:1.5px solid var(--accent);border-radius:8px;color:var(--accent);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.83rem;font-weight:600;padding:.38rem .9rem;text-decoration:none;transition:background .18s,color .18s}.btn-nav-auth:hover{background:var(--accent);color:#fff}.btn-logout{border-color:#e74c3c;color:#e74c3c}.btn-logout:hover{background:#e74c3c;color:#fff}@media (max-width:640px){.navbar-pro{gap:.4rem;height:52px;min-height:52px;padding:0 .6rem}.navbar-brand-pro{min-width:0}.brand-name{font-size:.95rem}.navbar-links-pro{gap:0}.nav-link-pro{padding:.4rem .6rem}.nav-label{display:none}.navbar-actions-pro{gap:.3rem;min-width:0}.btn-nav-auth{font-size:.78rem;padding:.3rem .6rem}.theme-toggle{font-size:1rem;height:32px;width:32px}}@media (max-width:400px){.brand-name{display:none}.nav-link-pro{padding:.4rem .5rem}}.login-page{align-items:center;background:var(--bg-primary);display:flex;height:100%;justify-content:center;overflow:hidden;position:relative;width:100%}.login-blob{-webkit-animation:blobFloat 8s ease-in-out infinite alternate;animation:blobFloat 8s ease-in-out infinite alternate;border-radius:50%;-webkit-filter:blur(80px);filter:blur(80px);opacity:.18;pointer-events:none;position:absolute}.login-blob-1{-webkit-animation-delay:0s;animation-delay:0s;background:var(--accent);height:400px;left:-120px;top:-120px;width:400px}.login-blob-2{-webkit-animation-delay:3s;animation-delay:3s;background:#3498db;bottom:-100px;height:320px;right:-80px;width:320px}.login-blob-3{-webkit-animation-delay:1.5s;animation-delay:1.5s;background:#9b59b6;height:200px;right:20%;top:50%;width:200px}@-webkit-keyframes blobFloat{0%{-webkit-transform:translate(0) scale(1);transform:translate(0) scale(1)}to{-webkit-transform:translate(30px,-30px) scale(1.08);transform:translate(30px,-30px) scale(1.08)}}@keyframes blobFloat{0%{-webkit-transform:translate(0) scale(1);transform:translate(0) scale(1)}to{-webkit-transform:translate(30px,-30px) scale(1.08);transform:translate(30px,-30px) scale(1.08)}}.login-card{-webkit-animation:scaleIn .35s cubic-bezier(.34,1.56,.64,1) forwards;animation:scaleIn .35s cubic-bezier(.34,1.56,.64,1) forwards;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--bg-card);border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow);margin:1rem;max-width:420px;padding:2.5rem 2rem;position:relative;width:100%}.login-logo{align-items:center;display:flex;gap:.6rem;justify-content:center;margin-bottom:1.75rem}.login-logo-dot{background:var(--accent);border-radius:50%;box-shadow:0 0 16px var(--accent);height:14px;width:14px}.login-logo-text{color:var(--text-primary);font-size:1.5rem;font-weight:700;letter-spacing:-.4px}.login-tabs{background:var(--bg-tertiary);border-radius:10px;display:flex;margin-bottom:1.5rem;padding:3px}.login-tab{background:transparent;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;flex:1 1;font-family:inherit;font-size:.875rem;font-weight:600;padding:.5rem;transition:background .2s,color .2s}.login-tab.active{background:var(--bg-secondary);box-shadow:var(--shadow-sm);color:var(--accent)}.login-field{margin-bottom:1rem}.login-label{color:var(--text-secondary);display:block;font-size:.78rem;font-weight:600;letter-spacing:.3px;margin-bottom:.35rem;text-transform:uppercase}.login-input-wrap{align-items:center;display:flex;position:relative}.login-input{background:var(--bg-input);border:1.5px solid var(--border);border-radius:10px;color:var(--text-primary);font-family:inherit;font-size:.9rem;outline:none;padding:.7rem 2.6rem .7rem .85rem;transition:border-color .2s,box-shadow .2s;width:100%}.login-input::-webkit-input-placeholder{color:var(--text-tertiary)}.login-input::placeholder{color:var(--text-tertiary)}.login-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.login-input-icon{align-items:center;color:var(--text-tertiary);cursor:pointer;display:flex;font-size:1.1rem;position:absolute;right:.75rem;transition:color .18s}.login-input-icon:hover{color:var(--accent)}.login-btn{background:var(--accent);border:none;border-radius:10px;color:#fff;cursor:pointer;font-family:inherit;font-size:.95rem;font-weight:700;margin-top:.5rem;overflow:hidden;padding:.8rem;position:relative;transition:background .18s,box-shadow .18s,-webkit-transform .1s;transition:background .18s,transform .1s,box-shadow .18s;transition:background .18s,transform .1s,box-shadow .18s,-webkit-transform .1s;width:100%}.login-btn:hover{background:var(--accent-hover);box-shadow:0 4px 16px rgba(0,168,132,.35);-webkit-transform:translateY(-1px);transform:translateY(-1px)}.login-btn:active{-webkit-transform:translateY(0);transform:translateY(0)}.login-btn-spin{-webkit-animation:spin .7s linear infinite;animation:spin .7s linear infinite;border:2.5px solid hsla(0,0%,100%,.4);border-radius:50%;border-top-color:#fff;display:inline-block;height:18px;vertical-align:middle;width:18px}.login-error{-webkit-animation:fadeIn .25s ease;animation:fadeIn .25s ease;background:rgba(231,76,60,.12);border:1px solid rgba(231,76,60,.3);border-radius:8px;color:#e74c3c;font-size:.82rem;margin-bottom:1rem;padding:.6rem .85rem}@media (max-width:480px){.login-card{margin:.75rem;padding:2rem 1.25rem}}.feed-page{background:var(--bg-primary);height:100%;overflow-y:auto;width:100%}.feed-inner{margin:0 auto;max-width:1100px;padding:1.5rem 1rem 3rem}.feed-header{margin-bottom:1.5rem}.feed-title{color:var(--text-primary);font-size:1.6rem;font-weight:800;letter-spacing:-.5px}.feed-subtitle{color:var(--text-secondary);font-size:.85rem;margin-top:.2rem}.feed-api-notice{align-items:flex-start;-webkit-animation:fadeIn .3s ease;animation:fadeIn .3s ease;background:linear-gradient(135deg,rgba(255,193,7,.12),rgba(255,152,0,.08));border:1px solid rgba(255,193,7,.35);border-radius:14px;display:flex;gap:1rem;padding:1.25rem 1.5rem}.feed-api-notice-icon{flex-shrink:0;font-size:2rem}.feed-api-notice-text h3{color:#f39c12;font-size:.95rem;font-weight:700;margin-bottom:.35rem}.feed-api-notice-text p{color:var(--text-secondary);font-size:.82rem;line-height:1.6}.feed-api-notice-text code{background:var(--bg-tertiary);border-radius:4px;color:var(--accent);font-family:monospace;font-size:.8rem;padding:.1rem .35rem}.feed-layout{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:220px 1fr}@media (max-width:768px){.feed-layout{grid-template-columns:1fr}}.feed-categories{background:var(--bg-secondary);border:1px solid var(--border);border-radius:14px;height:-webkit-fit-content;height:-moz-fit-content;height:fit-content;padding:.75rem;position:-webkit-sticky;position:sticky;top:0}.feed-cat-title{color:var(--text-tertiary);font-size:.75rem;font-weight:700;letter-spacing:.8px;margin-bottom:.25rem;padding:.4rem .5rem;text-transform:uppercase}.feed-cat-search{align-items:center;background:var(--bg-tertiary);border-radius:8px;display:flex;gap:.4rem;margin-bottom:.6rem;padding:.4rem .6rem}.feed-cat-search input{background:transparent;border:none;color:var(--text-primary);flex:1 1;font-family:inherit;font-size:.8rem;outline:none}.feed-cat-search input::-webkit-input-placeholder{color:var(--text-tertiary)}.feed-cat-search input::placeholder{color:var(--text-tertiary)}.feed-cat-btn{align-items:center;background:transparent;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;font-family:inherit;font-size:.82rem;gap:.5rem;padding:.5rem .7rem;text-align:left;transition:background .15s,color .15s;width:100%}.feed-cat-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.feed-cat-btn.active{background:var(--accent-light);color:var(--accent);font-weight:600}.feed-cat-icon{font-size:1rem}.feed-country-select{background:var(--bg-tertiary);border:1.5px solid var(--border);border-radius:8px;color:var(--text-primary);cursor:pointer;font-family:inherit;font-size:.8rem;margin-top:.5rem;outline:none;padding:.45rem .6rem;transition:border-color .2s;width:100%}.feed-country-select:focus{border-color:var(--accent)}.feed-main{min-width:0}.feed-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.85rem}.feed-section-title{color:var(--text-primary);font-size:1rem;font-weight:700}.feed-section-badge{background:var(--accent-light);border-radius:8px;color:var(--accent);font-size:.72rem;font-weight:600;padding:.2rem .6rem}.feed-articles{display:flex;flex-direction:column;gap:.85rem}.news-card-pro{-webkit-animation:fadeIn .25s ease;animation:fadeIn .25s ease;background:var(--bg-secondary);border:1px solid var(--border);border-radius:14px;color:inherit;cursor:pointer;display:flex;gap:.85rem;overflow:hidden;padding:.85rem;text-decoration:none;transition:background .15s,box-shadow .15s,-webkit-transform .15s;transition:background .15s,transform .15s,box-shadow .15s;transition:background .15s,transform .15s,box-shadow .15s,-webkit-transform .15s}.news-card-pro:hover{background:var(--bg-hover);box-shadow:var(--shadow-sm);-webkit-transform:translateX(4px);transform:translateX(4px)}.news-card-img{background:var(--bg-tertiary);object-fit:cover}.news-card-img,.news-card-img-placeholder{border-radius:8px;flex-shrink:0;height:80px;width:100px}.news-card-img-placeholder{align-items:center;background:linear-gradient(135deg,var(--bg-tertiary),var(--bg-hover));display:flex;font-size:2rem;justify-content:center}.news-card-body{display:flex;flex:1 1;flex-direction:column;gap:.25rem;min-width:0}.news-card-source{color:var(--accent);font-size:.68rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.news-card-title{color:var(--text-primary);font-size:.875rem;font-weight:600;line-height:1.4}.news-card-desc,.news-card-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.news-card-desc{color:var(--text-secondary);font-size:.78rem;line-height:1.45}.news-card-meta{align-items:center;display:flex;gap:.75rem;margin-top:.2rem}.news-card-date{color:var(--text-tertiary);font-size:.68rem}.news-card-link{color:var(--accent);font-size:.68rem;font-weight:600;text-decoration:none}.news-card-link:hover{text-decoration:underline}.feed-loading{align-items:center;display:flex;justify-content:center;padding:3rem}.feed-spinner{-webkit-animation:spin .7s linear infinite;animation:spin .7s linear infinite;border:3px solid var(--border);border-radius:50%;border-top-color:var(--accent);height:36px;width:36px}@media (max-width:640px){.news-card-pro{flex-direction:column}.news-card-img,.news-card-img-placeholder{height:160px;width:100%}.feed-categories{position:static}}.chat-root{background:var(--bg-primary);width:100%}.chat-root,.chat-sidebar{display:flex;height:100%;overflow:hidden}.chat-sidebar{background:var(--bg-secondary);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;max-width:100%;transition:background .25s,border-color .25s;width:380px}@media (max-width:768px){.chat-sidebar{width:100%}}.chat-sidebar-header{border-bottom:1px solid var(--border);flex-shrink:0;padding:.75rem 1rem .5rem}.chat-sidebar-top{align-items:center;display:flex;gap:.4rem;margin-bottom:.6rem}.chat-sidebar-title{color:var(--text-primary);flex:1 1;font-size:1.1rem;font-weight:700}.chat-sidebar-icon-btn{align-items:center;background:transparent;border:none;border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;font-size:1.1rem;height:34px;justify-content:center;position:relative;transition:background .15s,color .15s;width:34px}.chat-sidebar-icon-btn:hover{background:var(--bg-hover);color:var(--accent)}.chat-search-wrap{align-items:center;background:var(--bg-tertiary);border-radius:10px;display:flex;gap:.5rem;margin-bottom:.25rem;padding:.45rem .75rem}.chat-search-icon{color:var(--text-tertiary);flex-shrink:0;font-size:1rem}.chat-search-input{background:transparent;border:none;color:var(--text-primary);flex:1 1;font-family:inherit;font-size:.875rem;outline:none}.chat-search-input::-webkit-input-placeholder{color:var(--text-tertiary)}.chat-search-input::placeholder{color:var(--text-tertiary)}.chat-contacts{flex:1 1;overflow-y:auto;padding:.25rem 0}.chat-tile-wrap{align-items:center;-webkit-animation:fadeIn .2s ease;animation:fadeIn .2s ease;cursor:pointer;display:flex;gap:.85rem;padding:.6rem 1rem;position:relative;transition:background .15s}.chat-tile-wrap:hover{background:var(--bg-hover)}.chat-tile-wrap.active{background:var(--bg-active)}.chat-tile-avatar-wrap{flex-shrink:0;position:relative}.chat-tile-avatar{object-fit:cover}.chat-tile-avatar,.chat-tile-avatar-ph{border-radius:50%;height:50px;width:50px}.chat-tile-avatar-ph{align-items:center;background:linear-gradient(135deg,var(--accent),#3498db);color:#fff;display:flex;font-size:.875rem;font-weight:700;justify-content:center}.chat-tile-online{background:var(--online);border:2px solid var(--bg-secondary);border-radius:50%;bottom:1px;height:13px;position:absolute;right:1px;width:13px}.chat-tile-body{flex:1 1;min-width:0}.chat-tile-row1{align-items:baseline;display:flex;gap:.5rem;justify-content:space-between;margin-bottom:.18rem}.chat-tile-name{color:var(--text-primary);flex:1 1;font-size:.9rem;font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-tile-time{color:var(--text-tertiary);flex-shrink:0;font-size:.72rem;white-space:nowrap}.chat-tile-row2{align-items:center;display:flex;gap:.5rem;justify-content:space-between}.chat-tile-preview{color:var(--text-secondary);flex:1 1;font-size:.8rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-tile-muted-icon{opacity:.6}.chat-tile-badge{align-items:center;-webkit-animation:bounceIn .25s ease;animation:bounceIn .25s ease;background:var(--accent);border-radius:10px;color:#fff;display:flex;flex-shrink:0;font-size:.68rem;font-weight:700;height:20px;justify-content:center;min-width:20px;padding:0 5px}.chat-tile-badge.muted{background:var(--text-tertiary)}.chat-ctx-menu{-webkit-animation:scaleIn .15s ease;animation:scaleIn .15s ease;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);min-width:160px;overflow:hidden;position:absolute;right:8px;top:100%;-webkit-transform-origin:top right;transform-origin:top right;z-index:200}.chat-ctx-item{color:var(--text-primary);cursor:pointer;font-size:.875rem;padding:.6rem 1rem;transition:background .15s}.chat-ctx-item:hover{background:var(--bg-hover)}.chat-ctx-item.danger{color:#e74c3c}.chat-ctx-item.danger:hover{background:rgba(231,76,60,.08)}.chat-user-menu{-webkit-animation:scaleIn .15s ease;animation:scaleIn .15s ease;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);min-width:180px;overflow:hidden;position:absolute;right:0;top:calc(100% + 6px);-webkit-transform-origin:top right;transform-origin:top right;z-index:300}.chat-menu-item{align-items:center;color:var(--text-primary);cursor:pointer;display:flex;font-size:.875rem;gap:.65rem;padding:.65rem 1rem;transition:background .15s}.chat-menu-item:hover{background:var(--bg-hover)}.chat-menu-item svg{color:var(--text-secondary);font-size:1rem}.chat-main{display:flex;flex:1 1;flex-direction:column;min-width:0;overflow:hidden}.chat-find-btn{background:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:600;margin-top:.75rem;padding:.5rem 1.25rem;transition:background .15s}.chat-find-btn:hover{background:var(--accent-hover)}.nav-badge{right:-4px;top:-4px}.nav-badge,.notif-bell-badge{align-items:center;-webkit-animation:bounceIn .25s ease;animation:bounceIn .25s ease;background:#e74c3c;border-radius:8px;color:#fff;display:flex;font-size:.58rem;font-weight:700;height:16px;justify-content:center;min-width:16px;padding:0 3px;position:absolute}.notif-bell-badge{pointer-events:none;right:-5px;top:-5px}.notif-dropdown{-webkit-animation:scaleIn .18s ease;animation:scaleIn .18s ease;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);left:0;overflow:hidden;position:fixed;top:116px;-webkit-transform-origin:top left;transform-origin:top left;width:min(320px,calc(100vw - 16px));z-index:9000}.notif-dropdown-header{align-items:center;border-bottom:1px solid var(--border);color:var(--text-primary);display:flex;font-size:.9rem;font-weight:700;justify-content:space-between;padding:.85rem 1rem .6rem}.notif-mark-all{background:none;border:none;color:var(--accent);cursor:pointer;font-family:inherit;font-size:.75rem;font-weight:600;padding:0}.notif-mark-all:hover{text-decoration:underline}.notif-list{max-height:340px;overflow-y:auto}.notif-empty{color:var(--text-tertiary);font-size:.84rem;padding:2rem 1rem;text-align:center}.notif-item{align-items:flex-start;border-bottom:1px solid var(--border);cursor:pointer;display:flex;gap:.75rem;padding:.7rem 1rem;position:relative;transition:background .15s}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--bg-hover)}.notif-item.unread{background:var(--accent-light)}.notif-item.unread:hover{background:var(--bg-hover)}.notif-icon{flex-shrink:0;font-size:1.4rem;line-height:1;margin-top:.1rem}.notif-body{flex:1 1;min-width:0}.notif-sender{color:var(--text-primary);font-size:.8rem;font-weight:700;margin-bottom:.1rem}.notif-text{color:var(--text-secondary);font-size:.78rem;line-height:1.35;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notif-time{color:var(--text-tertiary);font-size:.68rem;margin-top:.2rem}.notif-unread-dot{background:var(--accent);border-radius:50%;flex-shrink:0;height:8px;margin-top:.35rem;width:8px}.contact-skeleton{align-items:center;display:flex;gap:.85rem;padding:.65rem 1rem}.skel-avatar{-webkit-animation:skelShimmer 1.4s infinite;animation:skelShimmer 1.4s infinite;background:var(--border);border-radius:50%;flex-shrink:0;height:44px;width:44px}.skel-lines{display:flex;flex:1 1;flex-direction:column;gap:6px}.skel-line{-webkit-animation:skelShimmer 1.4s infinite;animation:skelShimmer 1.4s infinite;background:var(--border);border-radius:6px;height:10px}.skel-line.short{width:55%}.skel-line.xshort{height:8px;width:35%}@-webkit-keyframes skelShimmer{0%{opacity:.55}50%{opacity:1}to{opacity:.55}}@keyframes skelShimmer{0%{opacity:.55}50%{opacity:1}to{opacity:.55}}.chat-main-hidden{display:none!important}.chat-empty-state{align-items:center;color:var(--text-tertiary);display:flex;flex-direction:column;gap:.75rem;justify-content:center;padding:3rem 1.5rem;text-align:center}.chat-empty-icon{font-size:3rem;opacity:.35}.chat-empty-state p{color:var(--text-secondary);font-size:.85rem;margin:0}@-webkit-keyframes bounceIn{0%{opacity:0;-webkit-transform:scale(.5);transform:scale(.5)}70%{-webkit-transform:scale(1.15);transform:scale(1.15)}to{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}@keyframes bounceIn{0%{opacity:0;-webkit-transform:scale(.5);transform:scale(.5)}70%{-webkit-transform:scale(1.15);transform:scale(1.15)}to{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}@-webkit-keyframes scaleIn{0%{opacity:0;-webkit-transform:scale(.9);transform:scale(.9)}to{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}@keyframes scaleIn{0%{opacity:0;-webkit-transform:scale(.9);transform:scale(.9)}to{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}@-webkit-keyframes slideInLeft{0%{opacity:0;-webkit-transform:translateX(24px);transform:translateX(24px)}to{opacity:1;-webkit-transform:translateX(0);transform:translateX(0)}}@keyframes slideInLeft{0%{opacity:0;-webkit-transform:translateX(24px);transform:translateX(24px)}to{opacity:1;-webkit-transform:translateX(0);transform:translateX(0)}}@media (max-width:768px){.chat-root{position:relative}.chat-sidebar{border-right:none;width:100%}.chat-main{background:var(--bg-primary);inset:0;position:absolute;z-index:10}.chat-sidebar-header{padding:.6rem .75rem .4rem}.chat-sidebar-top{gap:.2rem}.chat-sidebar-title{font-size:1rem}.chat-sidebar-icon-btn{font-size:1rem;height:30px;width:30px}.chat-tile-wrap{padding:.55rem .75rem}.chat-tile-avatar,.chat-tile-avatar-ph{height:44px;width:44px}.chat-tile-avatar-ph{font-size:.8rem}.notif-dropdown{left:4px;top:56px;width:calc(100vw - 8px)}.chat-user-menu{min-width:160px;right:0}}@media (max-width:400px){.chat-sidebar-title{font-size:.9rem}.chat-tile-name{font-size:.82rem}.chat-tile-preview{font-size:.74rem}.chat-tile-time{font-size:.66rem}}.chatdesc-root{background:var(--bg-primary);display:flex;flex-direction:column;height:100%;position:relative}.chatdesc-header{align-items:center;background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;flex-shrink:0;gap:.75rem;min-height:60px;padding:.6rem 1rem;transition:background .25s}.chatdesc-back-btn{align-items:center;background:none;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;display:none;font-size:1.4rem;padding:.25rem;transition:color .15s,background .15s}.chatdesc-back-btn:hover{background:var(--bg-hover);color:var(--accent)}@media (max-width:768px){.chatdesc-back-btn{display:flex}}.chatdesc-avatar-wrap{flex-shrink:0;position:relative}.chatdesc-avatar{border-radius:50%;height:42px;object-fit:cover;width:42px}.chatdesc-avatar-placeholder{align-items:center;background:linear-gradient(135deg,var(--accent),#3498db);border-radius:50%;color:#fff;display:flex;font-size:.85rem;font-weight:700;height:42px;justify-content:center;width:42px}.chatdesc-online{border:2px solid var(--bg-secondary);border-radius:50%;bottom:0;height:11px;position:absolute;right:0;width:11px}.chatdesc-online.on{background:var(--online)}.chatdesc-online.off{background:var(--offline)}.chatdesc-info{flex:1 1;min-width:0}.chatdesc-name{color:var(--text-primary);font-size:.92rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chatdesc-status{font-size:.72rem;margin-top:1px}.chatdesc-status.on{color:var(--online)}.chatdesc-status.off{color:var(--text-tertiary)}.chatdesc-header-actions{align-items:center;display:flex;gap:.25rem}.chatdesc-icon-btn{align-items:center;background:transparent;border:none;border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;font-size:1.1rem;height:36px;justify-content:center;transition:background .15s,color .15s;width:36px}.chatdesc-icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.chatdesc-messages{background:var(--bg-primary);display:flex;flex:1 1;flex-direction:column;overflow-y:auto;padding:.75rem 0}.msg-date-sep{justify-content:center}.msg-date-sep span{background:var(--bg-tertiary);border-radius:12px;color:var(--text-secondary);font-weight:500;padding:.25rem .75rem}.chatdesc-input-area{background:var(--bg-secondary);border-top:1px solid var(--border);flex-shrink:0;padding:.6rem .75rem;transition:background .25s}.chatdesc-input-row{align-items:flex-end;background:var(--bg-input);border:1px solid var(--border);border-radius:26px;display:flex;gap:.5rem;padding:.4rem .75rem .4rem .5rem;transition:border-color .2s,box-shadow .2s}.chatdesc-input-row:focus-within{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-light)}.chatdesc-input-icon-btn{align-items:center;background:none;border:none;border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;font-size:1.25rem;padding:.3rem;transition:color .15s,background .15s}.chatdesc-input-icon-btn:hover{background:var(--bg-hover);color:var(--accent)}.chatdesc-input{background:transparent;border:none;color:var(--text-primary);flex:1 1;font-family:inherit;font-size:.9rem;line-height:1.45;max-height:120px;min-height:24px;outline:none;padding:.2rem 0;resize:none}.chatdesc-input::-webkit-input-placeholder{color:var(--text-tertiary)}.chatdesc-input::placeholder{color:var(--text-tertiary)}.chatdesc-send-btn{align-items:center;background:var(--accent);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:1rem;height:36px;justify-content:center;transition:background .15s,-webkit-transform .1s;transition:background .15s,transform .1s;transition:background .15s,transform .1s,-webkit-transform .1s;width:36px}.chatdesc-send-btn:hover{background:var(--accent-hover);-webkit-transform:scale(1.05);transform:scale(1.05)}.chatdesc-send-btn:disabled{background:var(--bg-tertiary);cursor:not-allowed;-webkit-transform:none;transform:none}.chatdesc-emoji-wrap{-webkit-animation:scaleIn .15s ease;animation:scaleIn .15s ease;left:8px;-webkit-transform-origin:bottom left;transform-origin:bottom left}.chatdesc-emoji-wrap,.poll-creator{bottom:72px;position:absolute;z-index:200}.poll-creator{-webkit-animation:scaleIn .2s ease;animation:scaleIn .2s ease;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);left:50%;padding:1.25rem;-webkit-transform:translateX(-50%);transform:translateX(-50%);width:min(360px,90vw)}.poll-creator h4{align-items:center;color:var(--text-primary);display:flex;font-size:.95rem;font-weight:700;gap:.5rem;margin-bottom:.85rem}.poll-creator-input{background:var(--bg-input);border:1.5px solid var(--border);border-radius:8px;color:var(--text-primary);font-family:inherit;font-size:.875rem;margin-bottom:.5rem;outline:none;padding:.55rem .75rem;transition:border-color .2s;width:100%}.poll-creator-input:focus{border-color:var(--accent)}.poll-creator-input::-webkit-input-placeholder{color:var(--text-tertiary)}.poll-creator-input::placeholder{color:var(--text-tertiary)}.poll-option-row{align-items:center;display:flex;gap:.4rem;margin-bottom:.4rem}.poll-remove-btn{background:none;border:none;border-radius:4px;color:var(--text-tertiary);cursor:pointer;font-size:1rem;padding:.25rem;transition:color .15s}.poll-remove-btn:hover{color:#e74c3c}.poll-add-option{background:none;border:1.5px dashed var(--border);border-radius:8px;color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:.83rem;margin-top:.25rem;padding:.45rem;transition:border-color .15s,color .15s;width:100%}.poll-add-option:hover{border-color:var(--accent);color:var(--accent)}.poll-creator-actions{display:flex;gap:.5rem;margin-top:.85rem}.poll-btn{border-radius:8px;cursor:pointer;flex:1 1;font-family:inherit;font-size:.83rem;font-weight:600;padding:.55rem;transition:background .15s,color .15s}.poll-btn-cancel{background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-secondary)}.poll-btn-cancel:hover{background:var(--bg-hover)}.poll-btn-send{background:var(--accent);border:none;color:#fff}.poll-btn-send:hover{background:var(--accent-hover)}.chatdesc-load-more{display:flex;justify-content:center;padding:.6rem}.chatdesc-load-btn{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:20px;color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:.78rem;font-weight:600;padding:.35rem 1rem;transition:background .15s,color .15s}.chatdesc-load-btn:hover{background:var(--bg-hover);color:var(--accent)}.chatdesc-load-spinner{-webkit-animation:spin .8s linear infinite;animation:spin .8s linear infinite;border:2.5px solid var(--border);border-radius:50%;border-top-color:var(--accent);height:20px;width:20px}.chatdesc-settings-menu{-webkit-animation:scaleIn .15s ease;animation:scaleIn .15s ease;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.2);min-width:180px;overflow:hidden;position:absolute;right:0;top:calc(100% + 6px);-webkit-transform-origin:top right;transform-origin:top right;z-index:300}.chatdesc-settings-item{color:var(--text-primary);cursor:pointer;font-size:.875rem;padding:.65rem 1rem;transition:background .15s}.chatdesc-settings-item:hover{background:var(--bg-hover)}.chatdesc-settings-item.danger{color:#e74c3c}.chatdesc-settings-item.danger:hover{background:rgba(231,76,60,.08)}.chatdesc-back-btn{display:flex!important}.chat-search-bar{align-items:center;-webkit-animation:fadeIn .15s ease;animation:fadeIn .15s ease;background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;flex-shrink:0;gap:.5rem;padding:.5rem .85rem}.chat-search-bar-input{background:var(--bg-tertiary);border:1.5px solid var(--border);border-radius:20px;color:var(--text-primary);flex:1 1;font-family:inherit;font-size:.875rem;outline:none;padding:.35rem .85rem;transition:border-color .2s}.chat-search-bar-input:focus{border-color:var(--accent)}.chat-search-bar-input::-webkit-input-placeholder{color:var(--text-tertiary)}.chat-search-bar-input::placeholder{color:var(--text-tertiary)}.chat-search-count{color:var(--text-tertiary);font-size:.75rem;padding:0 .25rem;white-space:nowrap}.chat-search-nav{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;font-size:.9rem;height:28px;justify-content:center;transition:background .15s,color .15s;width:28px}.chat-search-nav:hover{background:var(--bg-hover);color:var(--accent)}.chatdesc-typing-header{align-items:center;color:var(--accent);display:flex;font-size:.72rem;font-style:italic;gap:2px}.typing-dot{-webkit-animation:typingBounce 1.2s ease-in-out infinite;animation:typingBounce 1.2s ease-in-out infinite;background:var(--accent);border-radius:50%;flex-shrink:0;height:5px;width:5px}.typing-dot:nth-child(2){-webkit-animation-delay:.2s;animation-delay:.2s}.typing-dot:nth-child(3){-webkit-animation-delay:.4s;animation-delay:.4s}@-webkit-keyframes typingBounce{0%,60%,to{opacity:.5;-webkit-transform:translateY(0);transform:translateY(0)}30%{opacity:1;-webkit-transform:translateY(-4px);transform:translateY(-4px)}}@keyframes typingBounce{0%,60%,to{opacity:.5;-webkit-transform:translateY(0);transform:translateY(0)}30%{opacity:1;-webkit-transform:translateY(-4px);transform:translateY(-4px)}}.chatdesc-blocked-bar{background:rgba(231,76,60,.06);border-top:1px solid rgba(231,76,60,.2);color:#e74c3c;flex-shrink:0;font-size:.85rem;padding:.75rem 1rem;text-align:center}.chatdesc-reply-bar{align-items:center;-webkit-animation:fadeIn .15s ease;animation:fadeIn .15s ease;background:var(--bg-secondary);border-top:1px solid var(--border);display:flex;flex-shrink:0;gap:.75rem;padding:.45rem .85rem}.chatdesc-reply-content{flex:1 1;min-width:0}.chatdesc-reply-label{color:var(--accent);display:block;font-size:.72rem;font-weight:700;margin-bottom:.1rem}.chatdesc-reply-text{color:var(--text-secondary);display:block;font-size:.8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chatdesc-reply-close{align-items:center;background:none;border:none;border-radius:50%;color:var(--text-tertiary);cursor:pointer;display:flex;flex-shrink:0;font-size:1.1rem;padding:.2rem;transition:background .15s,color .15s}.chatdesc-reply-close:hover{background:var(--bg-hover);color:var(--text-primary)}.forward-dialog{-webkit-animation:scaleIn .18s ease;animation:scaleIn .18s ease;background:var(--bg-card);border-radius:16px;box-shadow:0 16px 48px rgba(0,0,0,.35);display:flex;flex-direction:column;margin:auto;overflow:hidden;width:min(340px,94vw)}.forward-header{align-items:center;color:var(--text-primary);display:flex;font-size:.95rem;font-weight:700;justify-content:space-between;padding:.85rem 1rem}.forward-header,.forward-preview{border-bottom:1px solid var(--border)}.forward-preview{color:var(--text-secondary);font-size:.8rem;font-style:italic;overflow:hidden;padding:.65rem 1rem;text-overflow:ellipsis;white-space:nowrap}.forward-list{max-height:280px;overflow-y:auto}.forward-item{align-items:center;border-bottom:1px solid var(--border);cursor:pointer;display:flex;gap:.75rem;padding:.65rem 1rem;transition:background .15s}.forward-item:hover{background:var(--bg-hover)}.forward-item:last-child{border-bottom:none}.forward-avatar{object-fit:cover}.forward-avatar,.forward-avatar-ph{border-radius:50%;flex-shrink:0;height:36px;width:36px}.forward-avatar-ph{align-items:center;background:linear-gradient(135deg,var(--accent),#3498db);color:#fff;display:flex;font-size:.72rem;font-weight:700;justify-content:center}.forward-item-name{color:var(--text-primary);font-size:.88rem;font-weight:600}@media (max-width:768px){.chatdesc-header{gap:.5rem;min-height:54px;padding:.5rem .75rem}.chatdesc-avatar{height:36px;width:36px}.chatdesc-avatar-placeholder{font-size:.78rem;height:36px;width:36px}.chatdesc-name{font-size:.85rem}.chatdesc-icon-btn{font-size:1rem;height:32px;width:32px}.chatdesc-header-actions{gap:.1rem}.chatdesc-messages{padding:.5rem 0}.chatdesc-input-area{padding:.5rem}.chatdesc-input-row{gap:.35rem;padding:.3rem .5rem .3rem .35rem}.chatdesc-input-icon-btn{font-size:1.1rem;padding:.25rem}.chatdesc-send-btn{font-size:.9rem;height:32px;width:32px}.chatdesc-input{font-size:.85rem}.chatdesc-emoji-wrap{bottom:64px;left:4px}.poll-creator{bottom:64px;width:calc(100vw - 16px)}.chat-search-bar{padding:.4rem .6rem}.forward-dialog{border-radius:12px;width:96vw}}@media (max-width:400px){.chatdesc-header{gap:.3rem}.chatdesc-icon-btn{font-size:.95rem;height:28px;width:28px}.chatdesc-name{font-size:.8rem}.chatdesc-input-row{border-radius:20px}}.no-chat-selected{align-items:center;-webkit-animation:fadeIn .4s ease;animation:fadeIn .4s ease;background:var(--bg-primary);color:var(--text-tertiary);display:flex;flex:1 1;flex-direction:column;gap:1rem;justify-content:center}.no-chat-icon{font-size:5rem;opacity:.25}.no-chat-selected h3{color:var(--text-secondary);font-size:1.2rem;font-weight:600}.no-chat-selected p{font-size:.85rem}.msg-row{align-items:flex-end;-webkit-animation:fadeIn .2s ease;animation:fadeIn .2s ease;display:flex;gap:.5rem;padding:.2rem 1rem;position:relative}.msg-row.out{flex-direction:row-reverse}.msg-row.in{flex-direction:row}.msg-row.msg-row-grouped{padding-top:.05rem}.msg-row.msg-row-highlighted{background:var(--accent-light);border-radius:8px}.msg-row.msg-row-optimistic{opacity:.55}.msg-avatar{object-fit:cover}.msg-avatar,.msg-avatar-placeholder{border-radius:50%;flex-shrink:0;height:30px;margin-bottom:4px;width:30px}.msg-avatar-placeholder{align-items:center;background:linear-gradient(135deg,var(--accent),#3498db);color:#fff;display:flex;font-size:.65rem;font-weight:700;justify-content:center}.msg-bubble-wrap{display:flex;flex-direction:column;gap:2px;max-width:min(72%,420px);position:relative}.msg-row.out .msg-bubble-wrap{align-items:flex-end}.msg-row.in .msg-bubble-wrap{align-items:flex-start}.msg-deleted{background:var(--bg-tertiary);border:1px dashed var(--border);border-radius:10px;color:var(--text-tertiary);font-size:.8rem;font-style:italic;padding:.4rem .75rem}.msg-bubble{border-radius:10px;cursor:default;font-size:.875rem;line-height:1.45;padding:.55rem .85rem .35rem;position:relative;transition:-webkit-filter .15s;transition:filter .15s;transition:filter .15s,-webkit-filter .15s;word-break:break-word}.msg-bubble:hover{-webkit-filter:brightness(1.05);filter:brightness(1.05)}.msg-bubble.out{background:var(--bg-message-out);border-radius:10px 10px 2px 10px;color:var(--text-primary)}.msg-bubble.in{background:var(--bg-message-in);border-radius:10px 10px 10px 2px;color:var(--text-primary)}.msg-text{display:block;white-space:pre-wrap}.msg-meta{align-items:center;display:flex;gap:.3rem;justify-content:flex-end;margin-top:.18rem}.msg-time{font-size:.65rem;white-space:nowrap}.msg-ticks,.msg-time{color:var(--text-tertiary)}.msg-ticks{align-items:center;display:inline-flex;font-size:.7rem;gap:-3px;letter-spacing:-.5px;line-height:1}.msg-ticks.read{color:#53bdeb}.msg-bubble-wrap:hover .msg-react-btn{opacity:1;pointer-events:all}.msg-react-btn{align-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:50%;box-shadow:0 2px 8px rgba(0,0,0,.15);cursor:pointer;display:flex;font-size:.85rem;height:28px;justify-content:center;opacity:0;pointer-events:none;position:absolute;top:50%;-webkit-transform:translateY(-50%);transform:translateY(-50%);transition:opacity .15s,-webkit-transform .15s;transition:opacity .15s,transform .15s;transition:opacity .15s,transform .15s,-webkit-transform .15s;width:28px;z-index:10}.msg-row.out .msg-react-btn{left:-36px}.msg-row.in .msg-react-btn{right:-36px}.msg-react-btn:hover{-webkit-transform:translateY(-50%) scale(1.2);transform:translateY(-50%) scale(1.2)}.reaction-picker{-webkit-animation:scaleIn .15s ease;animation:scaleIn .15s ease;background:var(--bg-card);border:1px solid var(--border);border-radius:30px;bottom:calc(100% + 8px);box-shadow:0 8px 24px rgba(0,0,0,.2);display:flex;gap:.25rem;padding:.35rem .5rem;position:absolute;z-index:100}.msg-row.out .reaction-picker{right:0}.msg-row.in .reaction-picker{left:0}.reaction-option{border-radius:50%;cursor:pointer;font-size:1.3rem;line-height:1;padding:.15rem;transition:-webkit-transform .1s;transition:transform .1s;transition:transform .1s,-webkit-transform .1s}.reaction-option:hover{-webkit-transform:scale(1.4);transform:scale(1.4)}.reaction-option.selected{background:var(--accent-light)}.msg-reactions{display:flex;flex-wrap:wrap;gap:3px;justify-content:flex-start;margin-top:3px}.msg-reactions.out{justify-content:flex-end}.msg-reaction-chip{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:12px;cursor:pointer;display:flex;font-size:.8rem;gap:3px;padding:2px 7px;transition:background .15s,border-color .15s}.msg-reaction-chip:hover{background:var(--bg-hover);border-color:var(--accent)}.msg-reaction-chip.mine{background:var(--accent-light);border-color:var(--accent)}.msg-reaction-chip span{color:var(--text-secondary);font-size:.7rem;font-weight:600}.msg-ctx-menu{-webkit-animation:scaleIn .15s ease;animation:scaleIn .15s ease;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.2);min-width:160px;overflow:hidden;position:absolute;top:calc(100% + 4px);z-index:200}.msg-ctx-menu.out{right:0;-webkit-transform-origin:top right;transform-origin:top right}.msg-ctx-menu.in{left:0;-webkit-transform-origin:top left;transform-origin:top left}.msg-ctx-item{color:var(--text-primary);cursor:pointer;font-size:.85rem;padding:.6rem 1rem;transition:background .15s}.msg-ctx-item:hover{background:var(--bg-hover)}.msg-ctx-item.danger{color:#e74c3c}.msg-ctx-item.danger:hover{background:rgba(231,76,60,.08)}.poll-card{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:12px;max-width:300px;min-width:220px;padding:.9rem}.poll-question{color:var(--text-primary);font-size:.9rem;font-weight:700;line-height:1.3;margin-bottom:.65rem}.poll-option{border-radius:8px;cursor:pointer;margin-bottom:.45rem;overflow:hidden;position:relative}.poll-option.revealed{cursor:default}.poll-bar-bg{background:var(--accent-light);height:100%;left:0;position:absolute;top:0;transition:width .4s ease;z-index:0}.poll-option-inner{align-items:center;border:1.5px solid var(--border);border-radius:8px;color:var(--text-primary);display:flex;font-size:.83rem;justify-content:space-between;padding:.45rem .65rem;position:relative;transition:border-color .15s;z-index:1}.poll-option:hover:not(.revealed) .poll-option-inner{border-color:var(--accent)}.poll-option.voted .poll-option-inner{border-color:var(--accent);font-weight:600}.poll-checkmark{color:var(--accent);font-size:.8rem;font-weight:700;position:absolute;right:.5rem;top:50%;-webkit-transform:translateY(-50%);transform:translateY(-50%);z-index:2}.poll-pct{color:var(--accent);font-size:.78rem;font-weight:600;margin-left:.4rem}.poll-votes{color:var(--text-tertiary);font-size:.72rem;margin-top:.5rem;text-align:right}.msg-date-sep{align-items:center;display:flex;gap:.75rem;margin:.75rem 0;text-align:center}.msg-date-sep:after,.msg-date-sep:before{background:var(--border);content:"";flex:1 1;height:1px}.msg-date-sep span{background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;color:var(--text-tertiary);font-size:.72rem;font-weight:600;padding:.2rem .6rem;white-space:nowrap}.msg-avatar-spacer{flex-shrink:0;width:30px}.msg-reply-quote{background:rgba(0,0,0,.06);border-left:3px solid var(--accent);border-radius:0 6px 6px 0;margin-bottom:.4rem;max-width:100%;overflow:hidden;padding:.3rem .6rem}.msg-reply-quote.out{background:rgba(0,0,0,.1);border-left-color:hsla(0,0%,100%,.5)}.msg-reply-name{color:var(--accent);font-size:.72rem;font-weight:700;margin-bottom:.1rem}.msg-reply-name,.msg-reply-preview{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msg-reply-preview{color:var(--text-secondary);font-size:.75rem}.msg-forwarded-label{font-size:.7rem;margin-bottom:.25rem}.msg-edited,.msg-forwarded-label{color:var(--text-tertiary);font-style:italic}.msg-edited{font-size:.62rem;margin-right:.25rem}.msg-highlight{background:#ffd60a;border-radius:2px;color:#000;padding:0 1px}.msg-edit-wrap{display:flex;flex-direction:column;gap:.35rem}.msg-edit-input{background:var(--bg-tertiary);border:1.5px solid var(--accent);border-radius:6px;color:var(--text-primary);font-family:inherit;font-size:.875rem;line-height:1.45;min-width:160px;outline:none;padding:.35rem .5rem;resize:none;width:100%}.msg-edit-actions{display:flex;gap:.4rem;justify-content:flex-end}.msg-edit-cancel,.msg-edit-save{border:none;border-radius:5px;cursor:pointer;font-family:inherit;font-size:.75rem;font-weight:600;padding:.2rem .6rem}.msg-edit-save{background:var(--accent);color:#fff}.msg-edit-save:hover{background:var(--accent-hover)}.msg-edit-cancel{background:var(--bg-tertiary);color:var(--text-secondary)}.msg-edit-cancel:hover{background:var(--bg-hover)}.userinfo-overlay{align-items:stretch;-webkit-animation:fadeIn .2s ease;animation:fadeIn .2s ease;background:rgba(0,0,0,.45);display:flex;inset:0;justify-content:flex-end;position:fixed;z-index:1000}.userinfo-panel{-webkit-animation:slideInRight .22s ease;animation:slideInRight .22s ease;border-left:1px solid var(--border);flex-direction:column;overflow-y:auto;width:min(360px,100vw)}.userinfo-header,.userinfo-panel{background:var(--bg-secondary);display:flex}.userinfo-header{align-items:center;border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;padding:.85rem 1rem}.userinfo-title{color:var(--text-primary);font-size:.95rem;font-weight:700}.userinfo-close{align-items:center;background:none;border:none;border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;font-size:1.3rem;padding:.2rem;transition:background .15s,color .15s}.userinfo-close:hover{background:var(--bg-hover);color:var(--accent)}.userinfo-hero{align-items:center;background:var(--bg-card);border-bottom:1px solid var(--border);display:flex;flex-direction:column;padding:2rem 1rem 1.25rem}.userinfo-avatar{box-shadow:0 4px 16px rgba(0,0,0,.2);object-fit:cover}.userinfo-avatar,.userinfo-avatar-ph{border-radius:50%;height:100px;margin-bottom:.75rem;width:100px}.userinfo-avatar-ph{align-items:center;background:linear-gradient(135deg,var(--accent),#3498db);color:#fff;display:flex;font-size:1.6rem;font-weight:700;justify-content:center}.userinfo-name{color:var(--text-primary);font-size:1.2rem;font-weight:700;margin-bottom:.3rem;text-align:center}.userinfo-status{color:var(--text-tertiary);font-size:.8rem}.userinfo-status.on{color:var(--online)}.userinfo-actions{border-bottom:1px solid var(--border);display:flex;gap:1.5rem;justify-content:center;padding:1rem 1rem .75rem}.userinfo-action-btn{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:12px;color:var(--text-secondary);cursor:pointer;display:flex;flex-direction:column;font-family:inherit;font-size:1.3rem;gap:.3rem;min-width:64px;padding:.65rem 1rem;transition:background .15s,color .15s,border-color .15s}.userinfo-action-btn span{color:var(--text-secondary);font-size:.7rem;font-weight:600}.userinfo-action-btn:hover{background:var(--bg-hover);border-color:var(--accent);color:var(--accent)}.userinfo-action-btn.active{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.userinfo-section{border-bottom:1px solid var(--border);padding:.9rem 1rem .7rem}.userinfo-section-label{color:var(--accent);font-size:.7rem;font-weight:700;letter-spacing:.04em;margin-bottom:.3rem;text-transform:uppercase}.userinfo-bio{color:var(--text-primary);font-size:.88rem;line-height:1.5}.userinfo-field-val{color:var(--text-primary);font-size:.875rem}.userinfo-danger-zone{display:flex;flex-direction:column;gap:.25rem;padding:.75rem 1rem}.userinfo-danger-btn{align-items:center;background:none;border:none;border-radius:8px;color:#e74c3c;cursor:pointer;display:flex;font-family:inherit;font-size:.875rem;gap:.6rem;padding:.65rem .75rem;text-align:left;transition:background .15s;width:100%}.userinfo-danger-btn:hover{background:rgba(231,76,60,.08)}.userinfo-danger-btn svg{font-size:1.1rem}.userinfo-confirm{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:.83rem;padding:.75rem}.userinfo-confirm-actions{display:flex;gap:.5rem;margin-top:.6rem}.userinfo-confirm-yes{background:#e74c3c;border:none;border-radius:6px;color:#fff}.userinfo-confirm-no,.userinfo-confirm-yes{cursor:pointer;flex:1 1;font-family:inherit;font-size:.8rem;font-weight:600;padding:.4rem}.userinfo-confirm-no{background:var(--bg-hover);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary)}.call-overlay{align-items:center;background:#0b0c10;display:flex;flex-direction:column;inset:0;justify-content:center;overflow:hidden;position:fixed;z-index:10000}.call-remote-video{background:#0b0c10;height:100%;inset:0;object-fit:contain;position:absolute;width:100%}.call-avatar-bg{align-items:center;background:linear-gradient(135deg,#1a1a2e,#16213e 60%,#0f3460);display:flex;flex-direction:column;gap:1rem;inset:0;justify-content:center;position:absolute}.call-avatar-circle{object-fit:cover}.call-avatar-circle,.call-avatar-ph{border:4px solid hsla(0,0%,100%,.25);border-radius:50%;box-shadow:0 0 40px rgba(99,179,237,.35);height:120px;width:120px}.call-avatar-ph{align-items:center;-webkit-animation:callPulse 2s ease-in-out infinite;animation:callPulse 2s ease-in-out infinite;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;font-size:2.8rem;font-weight:700;justify-content:center}@-webkit-keyframes callPulse{0%,to{box-shadow:0 0 40px rgba(99,179,237,.35)}50%{box-shadow:0 0 70px rgba(99,179,237,.6)}}@keyframes callPulse{0%,to{box-shadow:0 0 40px rgba(99,179,237,.35)}50%{box-shadow:0 0 70px rgba(99,179,237,.6)}}.call-partner-name{color:#fff;font-size:1.6rem;font-weight:700;text-shadow:0 2px 8px rgba(0,0,0,.5)}.call-status-text{color:hsla(0,0%,100%,.65);font-size:.9rem;letter-spacing:.05em}.call-incoming-overlay{align-items:center;-webkit-animation:fadeIn .2s ease;animation:fadeIn .2s ease;background:rgba(0,0,0,.82);display:flex;inset:0;justify-content:center;position:fixed;z-index:10001}.call-incoming-card{align-items:center;-webkit-animation:slideUp .3s cubic-bezier(.34,1.56,.64,1);animation:slideUp .3s cubic-bezier(.34,1.56,.64,1);background:linear-gradient(135deg,#1a1a2e,#0f3460);border-radius:24px;box-shadow:0 24px 80px rgba(0,0,0,.7);display:flex;flex-direction:column;gap:1rem;padding:2.5rem 2rem;width:min(340px,90vw)}@-webkit-keyframes slideUp{0%{opacity:0;-webkit-transform:translateY(40px);transform:translateY(40px)}to{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;-webkit-transform:translateY(40px);transform:translateY(40px)}to{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}.call-incoming-type{color:hsla(0,0%,100%,.55);font-size:.8rem;letter-spacing:.12em;text-transform:uppercase}.call-incoming-avatar{border:3px solid hsla(0,0%,100%,.25);border-radius:50%;object-fit:cover}.call-incoming-avatar,.call-incoming-avatar-ph{-webkit-animation:callPulse 1.8s ease-in-out infinite;animation:callPulse 1.8s ease-in-out infinite;height:96px;width:96px}.call-incoming-avatar-ph{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;font-size:2.2rem;font-weight:700;justify-content:center}.call-incoming-name{color:#fff;font-size:1.4rem;font-weight:700}.call-incoming-label{color:hsla(0,0%,100%,.55);font-size:.85rem;margin-top:-.4rem}.call-incoming-actions{display:flex;gap:2.5rem;margin-top:.5rem}.call-accept-btn,.call-decline-btn{align-items:center;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:1.6rem;height:64px;justify-content:center;transition:box-shadow .15s,-webkit-transform .15s;transition:transform .15s,box-shadow .15s;transition:transform .15s,box-shadow .15s,-webkit-transform .15s;width:64px}.call-accept-btn{-webkit-animation:ringPulse 1.4s ease-in-out infinite;animation:ringPulse 1.4s ease-in-out infinite;background:#22c55e;box-shadow:0 0 24px rgba(34,197,94,.5);color:#fff}.call-decline-btn{background:#ef4444;box-shadow:0 0 24px rgba(239,68,68,.4);color:#fff}.call-accept-btn:hover,.call-decline-btn:hover{-webkit-transform:scale(1.1);transform:scale(1.1)}@-webkit-keyframes ringPulse{0%,to{box-shadow:0 0 24px rgba(34,197,94,.5)}50%{box-shadow:0 0 44px rgba(34,197,94,.8)}}@keyframes ringPulse{0%,to{box-shadow:0 0 24px rgba(34,197,94,.5)}50%{box-shadow:0 0 44px rgba(34,197,94,.8)}}.call-btn-label{color:hsla(0,0%,100%,.55);font-size:.7rem;margin-top:.3rem;text-align:center}.call-local-pip{background:#111;border:2px solid hsla(0,0%,100%,.3);border-radius:14px;bottom:110px;box-shadow:0 4px 24px rgba(0,0,0,.5);cursor:pointer;height:90px;overflow:hidden;position:absolute;right:20px;transition:-webkit-transform .15s;transition:transform .15s;transition:transform .15s,-webkit-transform .15s;width:120px;z-index:2}.call-local-pip:hover{-webkit-transform:scale(1.05);transform:scale(1.05)}.call-local-pip video{height:100%;object-fit:cover;-webkit-transform:scaleX(-1);transform:scaleX(-1);width:100%}.call-pip-off{background:#1a1a2e;color:hsla(0,0%,100%,.4);font-size:.7rem;height:100%;justify-content:center;width:100%}.call-controls,.call-pip-off{align-items:center;display:flex}.call-controls{backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:rgba(0,0,0,.55);border:1px solid hsla(0,0%,100%,.08);border-radius:60px;bottom:28px;gap:16px;left:50%;padding:10px 20px;position:absolute;-webkit-transform:translateX(-50%);transform:translateX(-50%);z-index:3}.call-ctrl-btn{align-items:center;background:hsla(0,0%,100%,.12);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.25rem;height:52px;justify-content:center;position:relative;transition:background .15s,-webkit-transform .12s;transition:background .15s,transform .12s;transition:background .15s,transform .12s,-webkit-transform .12s;width:52px}.call-ctrl-btn:hover{background:hsla(0,0%,100%,.22);-webkit-transform:scale(1.08);transform:scale(1.08)}.call-ctrl-btn.active{background:#6c63ff;background:var(--accent,#6c63ff)}.call-ctrl-btn.off{background:hsla(0,0%,100%,.06);color:hsla(0,0%,100%,.35)}.call-ctrl-btn.danger{background:#ef4444}.call-ctrl-btn.danger:hover{background:#dc2626}.call-ctrl-label{bottom:-18px;color:hsla(0,0%,100%,.45);font-size:.58rem;pointer-events:none;white-space:nowrap}.call-ctrl-label,.call-duration{left:50%;position:absolute;-webkit-transform:translateX(-50%);transform:translateX(-50%)}.call-duration{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:rgba(0,0,0,.45);border:1px solid hsla(0,0%,100%,.1);border-radius:20px;color:hsla(0,0%,100%,.85);font-size:.85rem;font-weight:600;padding:.3rem .85rem;top:16px;z-index:3}.call-screen-share-banner{background:rgba(99,179,237,.2);border:1px solid rgba(99,179,237,.4);border-radius:10px;color:#63b3ed;font-size:.75rem;padding:.3rem .75rem;position:absolute;right:20px;top:16px;z-index:3}@-webkit-keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.call-ctrl-group{align-items:center;display:flex;gap:2px;position:relative}.call-ctrl-chevron{align-items:center;align-self:flex-end;background:hsla(0,0%,100%,.08);border:none;border-radius:50%;color:hsla(0,0%,100%,.55);cursor:pointer;display:flex;font-size:.7rem;height:20px;justify-content:center;margin-bottom:4px;transition:background .15s;width:20px}.call-ctrl-chevron:hover{background:hsla(0,0%,100%,.18);color:#fff}.call-device-picker{-webkit-animation:slideUp .18s ease;animation:slideUp .18s ease;background:#1e2030;border:1px solid hsla(0,0%,100%,.12);border-radius:12px;bottom:calc(100% + 10px);box-shadow:0 8px 32px rgba(0,0,0,.6);left:0;min-width:220px;overflow:hidden;position:absolute;z-index:10}.call-device-item{color:hsla(0,0%,100%,.8);cursor:pointer;font-size:.82rem;overflow:hidden;padding:.65rem 1rem;text-overflow:ellipsis;transition:background .12s;white-space:nowrap}.call-device-item:hover{background:hsla(0,0%,100%,.08)}.call-device-item.selected{color:#63b3ed}.call-chat-panel{-webkit-animation:slideInRight .22s ease;animation:slideInRight .22s ease;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:rgba(14,16,26,.92);border-left:1px solid hsla(0,0%,100%,.08);display:flex;flex-direction:column;height:100%;position:absolute;right:0;top:0;width:300px;z-index:4}@-webkit-keyframes slideInRight{0%{opacity:0;-webkit-transform:translateX(100%);transform:translateX(100%)}to{opacity:1;-webkit-transform:translateX(0);transform:translateX(0)}}@keyframes slideInRight{0%{opacity:0;-webkit-transform:translateX(100%);transform:translateX(100%)}to{opacity:1;-webkit-transform:translateX(0);transform:translateX(0)}}.call-chat-header{align-items:center;border-bottom:1px solid hsla(0,0%,100%,.08);color:#fff;display:flex;font-size:.9rem;font-weight:600;justify-content:space-between;padding:.85rem 1rem}.call-chat-close{background:none;border:none;color:hsla(0,0%,100%,.5);cursor:pointer;font-size:1rem;line-height:1;padding:0}.call-chat-close:hover{color:#fff}.call-chat-messages{display:flex;flex:1 1;flex-direction:column;gap:.5rem;overflow-y:auto;padding:.75rem}.call-chat-empty{color:hsla(0,0%,100%,.3);font-size:.78rem;margin-top:2rem;text-align:center}.call-chat-bubble{border-radius:12px;font-size:.82rem;line-height:1.35;max-width:85%;padding:.45rem .7rem}.call-chat-bubble.mine{align-self:flex-end;background:#4f46e5;border-bottom-right-radius:4px;color:#fff}.call-chat-bubble.theirs{align-self:flex-start;background:hsla(0,0%,100%,.1);border-bottom-left-radius:4px;color:hsla(0,0%,100%,.9)}.call-chat-from{color:hsla(0,0%,100%,.45);font-size:.68rem;margin-bottom:.15rem}.call-chat-text{word-break:break-word}.call-chat-input-row{align-items:center;border-top:1px solid hsla(0,0%,100%,.08);display:flex;gap:.5rem;padding:.65rem .75rem}.call-chat-input{background:hsla(0,0%,100%,.08);border:1px solid hsla(0,0%,100%,.1);border-radius:20px;color:#fff;flex:1 1;font-family:inherit;font-size:.82rem;outline:none;padding:.45rem .85rem}.call-chat-input::-webkit-input-placeholder{color:hsla(0,0%,100%,.3)}.call-chat-input::placeholder{color:hsla(0,0%,100%,.3)}.call-chat-send{align-items:center;background:#4f46e5;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:1rem;height:36px;justify-content:center;transition:background .15s;width:36px}.call-chat-send:hover{background:#4338ca}.call-games-panel{-webkit-animation:slideInRight .22s ease;animation:slideInRight .22s ease;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:rgba(10,10,18,.96);border-left:1px solid hsla(0,0%,100%,.08);display:flex;flex-direction:column;height:100%;overflow:hidden;position:absolute;right:0;top:0;width:340px;z-index:4}@media (max-width:480px){.call-chat-panel,.call-games-panel{border-left:none;width:100%}.call-avatar-circle,.call-avatar-ph{font-size:2rem;height:90px;width:90px}.call-partner-name{font-size:1.3rem}.call-local-pip{bottom:100px;height:70px;right:12px;width:90px}.call-controls{gap:10px;padding:8px 14px}.call-ctrl-btn{font-size:1.1rem;height:46px;width:46px}}.gh-root{background:#0f0f14;color:#fff;display:flex;flex-direction:column;height:100%;overflow:hidden}.gh-root.playing{background:#0d0d12}.gh-root.fullscreen{height:100vh;inset:0;position:fixed;width:100vw;z-index:10002}.gh-invite-card{align-items:center;-webkit-animation:slideUp .25s ease;animation:slideUp .25s ease;background:linear-gradient(135deg,rgba(108,99,255,.2),rgba(99,102,241,.05));border:1px solid rgba(108,99,255,.3);border-radius:18px;display:flex;flex-direction:column;gap:12px;margin:auto;padding:2rem 1.25rem;width:min(280px,92%)}.gh-invite-emoji{-webkit-animation:pulse 1.6s ease-in-out infinite;animation:pulse 1.6s ease-in-out infinite;font-size:3rem}.gh-invite-title{color:hsla(0,0%,100%,.75);font-size:.85rem;text-align:center}.gh-invite-game{font-size:1.15rem;font-weight:700}.gh-invite-actions{display:flex;gap:10px;margin-top:.5rem}.gh-invite-accept,.gh-invite-decline{border:none;border-radius:22px;cursor:pointer;font-family:inherit;font-size:.82rem;font-weight:700;padding:.5rem 1.1rem;transition:opacity .15s,-webkit-transform .12s;transition:transform .12s,opacity .15s;transition:transform .12s,opacity .15s,-webkit-transform .12s}.gh-invite-accept{background:#22c55e;color:#fff}.gh-invite-decline{background:hsla(0,0%,100%,.12);color:#fff}.gh-invite-accept:hover,.gh-invite-decline:hover{-webkit-transform:scale(1.06);transform:scale(1.06)}.gh-waiting{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:16px;justify-content:center;padding:1.5rem}.gh-waiting-text{color:hsla(0,0%,100%,.7);font-size:.9rem;text-align:center}.gh-cancel-btn{background:rgba(239,68,68,.2);border:1px solid rgba(239,68,68,.4);border-radius:20px;color:#fca5a5;cursor:pointer;font-family:inherit;font-size:.78rem;font-weight:600;padding:.45rem 1rem}.gh-cancel-btn:hover{background:rgba(239,68,68,.3)}.gh-header{align-items:center;background:hsla(0,0%,100%,.04);border-bottom:1px solid hsla(0,0%,100%,.08);display:flex;flex-shrink:0;justify-content:space-between;padding:.65rem 1rem}.gh-title{font-size:.95rem;font-weight:700;letter-spacing:.02em}.gh-header-actions{align-items:center;display:flex;gap:8px}.gh-close-btn,.gh-icon-btn{background:hsla(0,0%,100%,.1);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.85rem;padding:.3rem .55rem;transition:background .15s}.gh-close-btn:hover,.gh-icon-btn:hover{background:hsla(0,0%,100%,.22)}.gh-game-grid{grid-gap:8px;display:grid;flex:1 1;gap:8px;grid-template-columns:repeat(2,1fr);overflow-y:auto;padding:10px}.gh-game-card{align-items:center;background:hsla(0,0%,100%,.06);border:1px solid hsla(0,0%,100%,.1);border-radius:14px;color:#fff;cursor:pointer;display:flex;flex-direction:column;font-family:inherit;gap:4px;padding:.75rem .5rem;transition:background .15s,-webkit-transform .12s;transition:background .15s,transform .12s;transition:background .15s,transform .12s,-webkit-transform .12s}.gh-game-card:hover{background:hsla(0,0%,100%,.13);-webkit-transform:scale(1.03);transform:scale(1.03)}.gh-game-emoji{font-size:1.8rem}.gh-game-label{font-size:.78rem;font-weight:700;text-align:center}.gh-game-desc{color:hsla(0,0%,100%,.5);font-size:.65rem;text-align:center}.gh-game-area{flex:1 1;overflow-y:auto}.gh-game-area,.gh-loading{display:flex;flex-direction:column}.gh-loading{align-items:center;color:hsla(0,0%,100%,.5);flex:1 1;font-size:.85rem;gap:12px;justify-content:center}.gh-spinner{-webkit-animation:spin 1s linear infinite;animation:spin 1s linear infinite;border:3px solid hsla(0,0%,100%,.15);border-radius:50%;border-top:3px solid var(--accent,#6c63ff);height:32px;width:32px}@-webkit-keyframes spin{to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}@keyframes spin{to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}.gh-result-bar{align-items:center;background:rgba(0,0,0,.5);border-top:1px solid hsla(0,0%,100%,.1);display:flex;flex-shrink:0;gap:10px;justify-content:center;padding:.75rem}.gh-result-text{font-size:.95rem;font-weight:700}.gh-lobby-btn,.gh-rematch-btn{border:none;border-radius:20px;cursor:pointer;font-size:.8rem;font-weight:600;padding:.35rem .8rem;transition:opacity .15s}.gh-rematch-btn{background:#6c63ff;color:#fff}.gh-lobby-btn{background:hsla(0,0%,100%,.15);color:#fff}.gh-lobby-btn:hover,.gh-rematch-btn:hover{opacity:.85}.gh-logs-panel{display:flex;flex-direction:column;height:100%}.gh-logs-header{align-items:center;border-bottom:1px solid hsla(0,0%,100%,.08);display:flex;font-weight:700;justify-content:space-between;padding:.65rem 1rem}.gh-stats-row{border-bottom:1px solid hsla(0,0%,100%,.06);display:flex;gap:12px;padding:.75rem 1rem}.gh-stat{align-items:center;background:hsla(0,0%,100%,.07);border-radius:20px;display:flex;font-size:.85rem;font-weight:700;gap:6px;padding:.3rem .7rem}.gh-stat.win{color:#22c55e}.gh-stat.loss{color:#ef4444}.gh-stat.draw{color:#eab308}.gh-log-list{flex:1 1;overflow-y:auto;padding:.5rem}.gh-log-empty{color:hsla(0,0%,100%,.4);font-size:.8rem;padding:2rem;text-align:center}.gh-log-item{align-items:center;background:hsla(0,0%,100%,.04);border-radius:10px;display:flex;gap:10px;margin-bottom:4px;padding:.55rem .75rem}.gh-log-item.win{border-left:3px solid #22c55e}.gh-log-item.loss{border-left:3px solid #ef4444}.gh-log-item.draw{border-left:3px solid #eab308}.gh-log-emoji{font-size:1.2rem}.gh-log-info{display:flex;flex:1 1;flex-direction:column;gap:2px}.gh-log-game{font-size:.78rem;font-weight:600}.gh-log-opp{color:hsla(0,0%,100%,.5);font-size:.7rem}.gh-log-result{font-size:1.1rem}.game-players-bar{align-items:center;background:hsla(0,0%,100%,.05);border-bottom:1px solid hsla(0,0%,100%,.06);display:flex;flex-shrink:0;justify-content:space-between;padding:.5rem .75rem}.game-player-chip{background:hsla(0,0%,100%,.12);border-radius:20px;font-size:.72rem;font-weight:700;padding:.25rem .6rem}.game-player-chip.mine{background:rgba(99,102,241,.35);color:#c7d2fe}.game-player-chip.opp{background:rgba(239,68,68,.25);color:#fca5a5}.game-vs{color:hsla(0,0%,100%,.45);font-size:.7rem}.game-status-text{border-top:1px solid hsla(0,0%,100%,.06);color:hsla(0,0%,100%,.85);flex-shrink:0;font-size:.85rem;font-weight:700;padding:.6rem;text-align:center}.game-start-btn{background:#6c63ff;border:none;border-radius:24px;color:#fff;cursor:pointer;display:block;font-size:.85rem;font-weight:700;margin:1rem auto;padding:.5rem 1.5rem}.game-start-btn:hover{background:#5a52d5}.game-ttt{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:8px;padding:.75rem .5rem}.game-ttt-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(3,1fr);width:min(220px,85vw)}.ttt-cell{align-items:center;aspect-ratio:1;background:hsla(0,0%,100%,.06);border:2px solid hsla(0,0%,100%,.12);border-radius:12px;cursor:default;display:flex;font-size:2rem;justify-content:center;transition:background .12s}.ttt-cell.clickable{cursor:pointer}.ttt-cell.clickable:hover{background:hsla(0,0%,100%,.14)}.ttt-cell.win-cell{background:rgba(34,197,94,.25);border-color:#22c55e}.ttt-symbol.x-sym{color:#818cf8}.ttt-symbol.o-sym{color:#f472b6}.game-c4{display:flex;flex:1 1;flex-direction:column;padding:.5rem}.c4-board{background:#1e3a8a;border-radius:10px;margin:auto;padding:6px}.c4-board,.c4-col{display:flex;gap:4px}.c4-col{cursor:pointer;flex-direction:column}.c4-col:hover .c4-cell:first-child{-webkit-filter:brightness(1.5);filter:brightness(1.5)}.c4-cell{background:#0f172a;border-radius:50%;height:28px;transition:background .1s;width:28px}.c4-cell.red{background:#ef4444;box-shadow:0 0 8px rgba(239,68,68,.6)}.c4-cell.yellow{background:#eab308;box-shadow:0 0 8px rgba(234,179,8,.6)}.game-rps{display:flex;flex:1 1;flex-direction:column;padding:.5rem}.rps-round-result{background:hsla(0,0%,100%,.06);border-radius:12px;margin:.5rem 0;padding:.75rem}.rps-choices-row{align-items:center;display:flex;gap:1rem;justify-content:center;margin-bottom:.5rem}.rps-choice-show{align-items:center;display:flex;flex-direction:column;gap:4px}.rps-emoji{font-size:2rem}.rps-label{color:hsla(0,0%,100%,.6);font-size:.7rem}.rps-vs-text{color:hsla(0,0%,100%,.4);font-size:.8rem}.rps-round-winner{font-size:.8rem;font-weight:700;text-align:center}.rps-pick-section{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:10px;padding:.5rem 0}.rps-pick-label{color:hsla(0,0%,100%,.6);font-size:.82rem}.rps-buttons{display:flex;gap:10px}.rps-btn{align-items:center;background:hsla(0,0%,100%,.07);border:2px solid hsla(0,0%,100%,.12);border-radius:14px;color:#fff;cursor:pointer;display:flex;flex-direction:column;font-family:inherit;gap:4px;padding:.65rem .9rem;transition:all .15s}.rps-btn:hover:not(:disabled){background:hsla(0,0%,100%,.18);-webkit-transform:scale(1.08);transform:scale(1.08)}.rps-btn.selected{background:rgba(108,99,255,.25);border-color:#6c63ff}.rps-btn:disabled{cursor:default;opacity:.5}.rps-btn-emoji{font-size:1.8rem}.rps-btn-label{font-size:.65rem}.rps-waiting-dot{-webkit-animation:pulse 1.5s ease-in-out infinite;animation:pulse 1.5s ease-in-out infinite;color:hsla(0,0%,100%,.5);font-size:.75rem}@-webkit-keyframes pulse{0%,to{opacity:.4}50%{opacity:1}}@keyframes pulse{0%,to{opacity:.4}50%{opacity:1}}.game-memory{display:flex;flex:1 1;flex-direction:column;padding:.5rem}.memory-grid{grid-gap:5px;display:grid;gap:5px;grid-template-columns:repeat(6,1fr);padding:.25rem}.memory-card{aspect-ratio:1;-webkit-perspective:400px;perspective:400px}.memory-card,.memory-card.clickable{cursor:pointer}.memory-card-inner{height:100%;position:relative;-webkit-transform-style:preserve-3d;transform-style:preserve-3d;transition:-webkit-transform .4s;transition:transform .4s;transition:transform .4s,-webkit-transform .4s;width:100%}.memory-card.revealed .memory-card-inner{-webkit-transform:rotateY(180deg);transform:rotateY(180deg)}.memory-card-back,.memory-card-front{align-items:center;-webkit-backface-visibility:hidden;backface-visibility:hidden;border-radius:8px;display:flex;font-size:1.1rem;inset:0;justify-content:center;position:absolute}.memory-card-back{background:rgba(108,99,255,.35);border:1px solid hsla(0,0%,100%,.1);color:hsla(0,0%,100%,.5)}.memory-card-front{background:hsla(0,0%,100%,.1);-webkit-transform:rotateY(180deg);transform:rotateY(180deg)}.memory-card.matched .memory-card-front{background:rgba(34,197,94,.25);border:1px solid #22c55e}.game-guess{display:flex;flex:1 1;flex-direction:column;padding:.75rem}.guess-hint-text{color:hsla(0,0%,100%,.6);font-size:.82rem;margin-bottom:.5rem;text-align:center}.guess-input-section{display:flex;flex-direction:column;gap:8px}.guess-input-row{display:flex;gap:8px}.guess-input{background:hsla(0,0%,100%,.08);border:1px solid hsla(0,0%,100%,.15);border-radius:10px;color:#fff;flex:1 1;font-size:.9rem;outline:none;padding:.45rem .75rem}.guess-btn{background:#6c63ff;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:.82rem;font-weight:700;padding:.45rem .9rem}.guess-history{display:flex;flex-direction:column;gap:4px;max-height:160px;overflow-y:auto}.guess-item{align-items:center;background:hsla(0,0%,100%,.05);border-radius:8px;display:flex;justify-content:space-between;padding:.3rem .6rem}.guess-num{font-size:.85rem;font-weight:700}.guess-result{color:hsla(0,0%,100%,.7);font-size:.8rem}.guess-waiting,.guess-watching{align-items:center;color:hsla(0,0%,100%,.6);display:flex;flex:1 1;flex-direction:column;font-size:.82rem;gap:10px;justify-content:center}.guess-spinner{-webkit-animation:spin 1s linear infinite;animation:spin 1s linear infinite;border:2px solid hsla(0,0%,100%,.1);border-radius:50%;border-top-color:#6c63ff;height:28px;width:28px}.game-speedmath{padding:.5rem}.game-speedmath,.math-question-area{display:flex;flex:1 1;flex-direction:column}.math-question-area{align-items:center;gap:12px;justify-content:center}.math-progress{color:hsla(0,0%,100%,.5);font-size:.72rem}.math-question{font-size:2rem;font-weight:700;letter-spacing:.05em}.math-input-row{display:flex;gap:8px}.math-input{background:hsla(0,0%,100%,.08);border:1px solid hsla(0,0%,100%,.2);border-radius:10px;color:#fff;font-size:1.1rem;outline:none;padding:.45rem .75rem;text-align:center;width:100px}.math-submit-btn{background:#22c55e;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:1rem;padding:.45rem .9rem}.math-waiting{color:hsla(0,0%,100%,.6);font-size:.82rem;gap:10px;justify-content:center}.game-word,.math-waiting{align-items:center;display:flex;flex:1 1;flex-direction:column}.game-word{gap:6px;overflow:hidden;padding:.4rem}.word-grid{flex-direction:column}.word-grid,.word-row{display:flex;gap:4px}.word-tile{align-items:center;border:2px solid hsla(0,0%,100%,.15);border-radius:6px;display:flex;font-size:.9rem;font-weight:700;height:36px;justify-content:center;transition:background .3s;width:36px}.word-tile.correct{background:#22c55e;border-color:#22c55e;color:#fff}.word-tile.present{background:#eab308;border-color:#eab308;color:#fff}.word-tile.absent{background:#374151;border-color:#374151;color:hsla(0,0%,100%,.5)}.word-current-input{display:flex;gap:4px;margin-top:2px}.word-tile.current{border-color:hsla(0,0%,100%,.3)}.word-tile.current.filled{border-color:#6c63ff}.word-keyboard{display:flex;flex-direction:column;gap:4px}.kb-row{display:flex;gap:3px;justify-content:center}.kb-key{background:hsla(0,0%,100%,.12);border:none;border-radius:5px;color:#fff;cursor:pointer;font-family:inherit;font-size:.72rem;font-weight:700;height:30px;transition:background .15s;width:26px}.kb-key.wide{font-size:.65rem;width:38px}.kb-key.correct,.kb-key.green{background:#22c55e}.kb-key.present{background:#eab308}.kb-key.absent{background:#1f2937;color:hsla(0,0%,100%,.35)}.kb-key:hover{background:hsla(0,0%,100%,.25)}.game-reflex{display:flex;flex:1 1;flex-direction:column}.reflex-area{border-radius:12px;cursor:pointer;flex:1 1;justify-content:center;margin:.5rem;transition:background .2s}.reflex-area,.reflex-content{align-items:center;display:flex}.reflex-content{flex-direction:column;gap:10px}.reflex-content.red-bg{background:rgba(239,68,68,.15)}.reflex-content.green-bg,.reflex-content.red-bg{border-radius:12px;height:100%;justify-content:center;width:100%}.reflex-content.green-bg{background:rgba(34,197,94,.2)}.reflex-icon{font-size:3rem}.reflex-start-btn{background:#6c63ff;border:none;border-radius:20px;color:#fff;cursor:pointer;font-size:.85rem;padding:.5rem 1.2rem}.reflex-early{color:#ef4444;font-size:.8rem;text-align:center}.game-typing{display:flex;flex:1 1;flex-direction:column;gap:8px;padding:.5rem}.typing-progress-bars{display:flex;flex-direction:column;gap:6px}.typing-pbar-wrap{align-items:center;display:flex;gap:8px}.typing-pbar-label{color:hsla(0,0%,100%,.6);flex-shrink:0;font-size:.7rem;width:50px}.typing-pbar{background:hsla(0,0%,100%,.08);border-radius:3px;flex:1 1;height:6px;overflow:hidden}.typing-pbar-fill{border-radius:3px;height:100%;transition:width .3s}.typing-pbar-fill.mine{background:#6c63ff}.typing-pbar-fill.opp{background:#ef4444}.typing-text-display{background:hsla(0,0%,100%,.05);border-radius:10px;font-size:.82rem;line-height:1.8;padding:.65rem;word-break:break-word}.typing-char{display:inline}.typing-char.correct{color:#4ade80}.typing-char.wrong{background:rgba(239,68,68,.2);border-radius:2px;color:#f87171}.typing-char.cursor{border-left:2px solid #6c63ff}.typing-char.pending{color:hsla(0,0%,100%,.4)}.typing-hidden-input{height:1px;opacity:0;pointer-events:none;position:absolute;width:1px}.game-snake{align-items:center;display:flex;flex:1 1;flex-direction:column;padding:.5rem}.snake-grid{background:#0a0a14;border:2px solid hsla(0,0%,100%,.1);border-radius:8px;display:grid;margin:auto;overflow:hidden}.snake-cell{height:16px;width:16px}.snake-cell.s1{background:#22c55e}.snake-cell.s2{background:#6366f1}.snake-cell.food{background:#f59e0b;border-radius:50%}.snake-controls-hint{color:hsla(0,0%,100%,.35);font-size:.65rem;margin-top:4px}.game-whack{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:8px;padding:.5rem}.whack-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(3,1fr);width:min(220px,85vw)}.whack-hole{align-items:center;aspect-ratio:1;background:hsla(0,0%,100%,.05);border:2px solid hsla(0,0%,100%,.1);border-radius:50%;cursor:pointer;display:flex;font-size:1.8rem;justify-content:center;overflow:hidden;position:relative;transition:background .1s}.whack-hole.active{background:hsla(0,0%,100%,.15);cursor:crosshair}.whack-mole{-webkit-animation:popUp .15s ease;animation:popUp .15s ease}@-webkit-keyframes popUp{0%{-webkit-transform:translateY(100%);transform:translateY(100%)}to{-webkit-transform:translateY(0);transform:translateY(0)}}@keyframes popUp{0%{-webkit-transform:translateY(100%);transform:translateY(100%)}to{-webkit-transform:translateY(0);transform:translateY(0)}}.friends-panel{background:var(--bg-primary);display:flex;flex-direction:column;height:100%;overflow:hidden}.friends-panel-header{align-items:center;background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;flex-shrink:0;gap:.75rem;padding:.85rem 1rem .6rem}.friends-panel-title{color:var(--text-primary);flex:1 1;font-size:1rem;font-weight:700}.friends-count-badge{align-items:center;-webkit-animation:bounceIn .3s ease;animation:bounceIn .3s ease;background:var(--accent);border-radius:11px;color:#fff;display:flex;font-size:.72rem;font-weight:700;height:22px;justify-content:center;min-width:22px;padding:0 6px}.friends-search{margin-top:.5rem}.friends-search-input{background:var(--bg-tertiary);border:1.5px solid var(--border);border-radius:10px;color:var(--text-primary);font-family:inherit;font-size:.875rem;outline:none;padding:.5rem .85rem;transition:border-color .2s;width:100%}.friends-search-input:focus{border-color:var(--accent)}.friends-search-input::-webkit-input-placeholder{color:var(--text-tertiary)}.friends-search-input::placeholder{color:var(--text-tertiary)}.friends-list{flex:1 1;overflow-y:auto;padding:.4rem 0}.friends-empty{align-items:center;color:var(--text-tertiary);display:flex;flex-direction:column;gap:.5rem;justify-content:center;padding:3rem 1rem;text-align:center}.friends-empty-icon{font-size:2.5rem}.friends-empty p{font-size:.85rem}.friend-row{align-items:center;-webkit-animation:fadeIn .2s ease;animation:fadeIn .2s ease;display:flex;gap:.75rem;padding:.65rem 1rem;transition:background .15s}.friend-row:hover{background:var(--bg-hover)}.friend-row-avatar-wrap{flex-shrink:0;position:relative}.friend-row-avatar{border-radius:50%;height:44px;object-fit:cover;width:44px}.friend-row-avatar-ph{align-items:center;background:linear-gradient(135deg,var(--accent),#3498db);border-radius:50%;color:#fff;display:flex;font-size:.8rem;font-weight:700;height:44px;justify-content:center;width:44px}.friend-online-dot{background:var(--online);border:2px solid var(--bg-secondary);border-radius:50%;bottom:1px;height:11px;position:absolute;right:1px;width:11px}.friend-row-info{flex:1 1;min-width:0}.friend-row-name{color:var(--text-primary);font-size:.875rem;font-weight:600}.friend-row-bio,.friend-row-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.friend-row-bio{color:var(--text-secondary);font-size:.75rem}.friend-row-actions{align-items:center;display:flex;flex-shrink:0;gap:.4rem}.friend-add-btn{align-items:center;background:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-family:inherit;font-size:.78rem;font-weight:600;gap:.35rem;padding:.38rem .75rem;transition:background .15s,opacity .15s;white-space:nowrap}.friend-add-btn:hover{background:var(--accent-hover)}.friend-add-btn:disabled{cursor:not-allowed;opacity:.6}.friend-accept-btn{align-items:center;background:var(--accent-light);border:none;border-radius:50%;color:var(--accent);cursor:pointer;display:flex;font-size:1.25rem;height:34px;justify-content:center;transition:background .15s,color .15s;width:34px}.friend-accept-btn:hover{background:var(--accent);color:#fff}.friend-accept-btn:disabled{cursor:not-allowed;opacity:.6}.friend-decline-btn{align-items:center;background:rgba(231,76,60,.1);border:none;border-radius:50%;color:#e74c3c;cursor:pointer;display:flex;font-size:1.25rem;height:34px;justify-content:center;transition:background .15s,color .15s;width:34px}.friend-decline-btn:hover{background:#e74c3c;color:#fff}.friend-decline-btn:disabled{cursor:not-allowed;opacity:.6}.friend-row-invite-btn{align-items:center;background:var(--bg-tertiary);border:none;border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;font-size:1rem;height:30px;justify-content:center;transition:background .15s,color .15s;width:30px}.friend-row-invite-btn:hover{background:var(--bg-hover);color:var(--accent)}.friend-status-badge{border-radius:8px;font-size:.72rem;font-weight:600;padding:.3rem .65rem;white-space:nowrap}.friend-status-badge.friend{background:var(--accent-light);color:var(--accent)}.friend-status-badge.pending{background:var(--bg-tertiary);color:var(--text-secondary)}.friend-status-badge.incoming{background:rgba(52,152,219,.12);color:#3498db}.friend-chat-btn{background:transparent;border:1.5px solid var(--accent);border-radius:7px;color:var(--accent);cursor:pointer;font-family:inherit;font-size:.72rem;font-weight:600;padding:.3rem .65rem;transition:background .15s,color .15s;white-space:nowrap}.friend-chat-btn:hover{background:var(--accent);color:#fff}.friend-cancel-btn{align-items:center;background:transparent;border:1px solid rgba(231,76,60,.3);border-radius:7px;color:#e74c3c;cursor:pointer;display:flex;font-family:inherit;font-size:.72rem;font-weight:600;gap:.3rem;padding:.3rem .6rem;transition:background .15s;white-space:nowrap}.friend-cancel-btn:hover{background:rgba(231,76,60,.1)}.friend-cancel-btn:disabled{cursor:not-allowed;opacity:.6}.profile-field-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;margin-bottom:.75rem;padding:1rem}.profile-field-label{color:var(--accent);font-size:.72rem;font-weight:700;letter-spacing:.4px;margin-bottom:.4rem;text-transform:uppercase}.profile-field-value{font-weight:500}.profile-edit-input,.profile-field-value{color:var(--text-primary);flex:1 1;font-size:.9rem}.profile-edit-input{background:var(--bg-tertiary);border:1.5px solid var(--accent);border-radius:8px;font-family:inherit;outline:none;padding:.45rem .75rem;width:100%}.profile-edit-btn{align-items:center;background:var(--bg-tertiary);border:none;border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;font-size:1rem;height:32px;justify-content:center;transition:color .15s;width:32px}.profile-edit-btn:hover{color:var(--accent)}.friend-remove-btn{background:transparent;border:1px solid rgba(231,76,60,.3);border-radius:7px;color:#e74c3c;cursor:pointer;font-family:inherit;font-size:.72rem;font-weight:600;padding:.3rem .6rem;transition:background .15s;white-space:nowrap}.friend-remove-btn:hover{background:rgba(231,76,60,.1)}.wx-page{background:var(--bg-primary);height:100%;overflow-y:auto;width:100%}.wx-container{align-items:center;color:#fff;display:flex;flex-direction:column;min-height:100%;padding:1.5rem 1rem 3rem;position:relative;transition:background 1.2s ease;width:100%}.wx-container:after,.wx-container:before{border-radius:50%;content:"";-webkit-filter:blur(80px);filter:blur(80px);opacity:.18;pointer-events:none;position:absolute;z-index:0}.wx-container:before{background:hsla(0,0%,100%,.4);height:400px;right:-80px;top:-60px;width:400px}.wx-container:after{background:rgba(0,0,0,.3);bottom:80px;height:300px;left:-60px;width:300px}.wx-container>*{position:relative;z-index:1}.wx-search-form{margin-bottom:1.5rem;max-width:500px;width:100%}.wx-search-wrap{align-items:center;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:hsla(0,0%,100%,.18);border:1px solid hsla(0,0%,100%,.3);border-radius:50px;display:flex;gap:.5rem;padding:.55rem .55rem .55rem 1.1rem;transition:box-shadow .2s,background .2s}.wx-search-wrap:focus-within{background:hsla(0,0%,100%,.25);box-shadow:0 0 0 3px hsla(0,0%,100%,.18),0 8px 32px rgba(0,0,0,.2)}.wx-search-loc{flex-shrink:0;font-size:1.15rem;opacity:.75}.wx-search-input{background:transparent;border:none;color:#fff;flex:1 1;font-family:inherit;font-size:.95rem;font-weight:500;outline:none}.wx-search-input::-webkit-input-placeholder{color:hsla(0,0%,100%,.55);font-weight:400}.wx-search-input::placeholder{color:hsla(0,0%,100%,.55);font-weight:400}.wx-search-btn{align-items:center;background:hsla(0,0%,100%,.28);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:1.1rem;height:38px;justify-content:center;transition:background .15s,-webkit-transform .1s;transition:background .15s,transform .1s;transition:background .15s,transform .1s,-webkit-transform .1s;width:38px}.wx-search-btn:hover{background:hsla(0,0%,100%,.4);-webkit-transform:scale(1.05);transform:scale(1.05)}.wx-loading{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:5rem}.wx-spinner{-webkit-animation:spin .8s linear infinite;animation:spin .8s linear infinite;border:4px solid hsla(0,0%,100%,.25);border-radius:50%;border-top-color:#fff;height:48px;width:48px}.wx-error{background:hsla(0,0%,100%,.08);border:1px solid hsla(0,0%,100%,.15);border-radius:20px;max-width:380px;opacity:.85;padding:3rem 1rem;text-align:center}.wx-error-icon{font-size:3.5rem;margin-bottom:.6rem}.wx-error p{font-size:.9rem;opacity:.8}.wx-content{-webkit-animation:fadeIn .4s ease;animation:fadeIn .4s ease;flex-direction:column;gap:1.25rem;max-width:640px;width:100%}.wx-city,.wx-content{align-items:center;display:flex}.wx-city{font-size:1rem;font-weight:600;gap:.4rem;letter-spacing:.2px;opacity:.85}.wx-hero{align-items:center;display:flex;flex-direction:column;gap:.1rem;padding:.5rem 0;text-align:center}.wx-hero-icon{-webkit-filter:drop-shadow(0 6px 18px rgba(0,0,0,.3));filter:drop-shadow(0 6px 18px rgba(0,0,0,.3));margin-bottom:-.5rem}.wx-temp{font-size:7rem;font-weight:200;letter-spacing:-5px;line-height:1;text-shadow:0 4px 24px rgba(0,0,0,.2)}.wx-desc{font-size:1.2rem;font-weight:500;margin-top:.2rem;opacity:.88;text-transform:capitalize}.wx-feels{font-size:.82rem;margin-top:.15rem;opacity:.6}.wx-minmax{display:flex;font-size:.9rem;font-weight:600;gap:1.25rem;margin-top:.4rem}.wx-max{opacity:.95}.wx-min{opacity:.55}.wx-pills{display:flex;flex-wrap:wrap;gap:.65rem;justify-content:center;width:100%}.wx-pill{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:hsla(0,0%,100%,.14);border:1px solid hsla(0,0%,100%,.2);border-radius:50px;display:flex;font-size:.8rem;font-weight:600;gap:.45rem;padding:.45rem .9rem;transition:background .18s,-webkit-transform .15s;transition:background .18s,transform .15s;transition:background .18s,transform .15s,-webkit-transform .15s;white-space:nowrap}.wx-pill:hover{background:hsla(0,0%,100%,.22);-webkit-transform:translateY(-2px);transform:translateY(-2px)}.wx-pill-icon{font-size:1.1rem;opacity:.85}.wx-sun-row{display:flex;gap:1rem;width:100%}.wx-sun-card{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.18);border-radius:16px;display:flex;flex:1 1;gap:.75rem;padding:.85rem 1rem}.wx-sun-icon{font-size:2rem;opacity:.85}.wx-sun-label{font-size:.68rem;font-weight:600;letter-spacing:.6px;opacity:.6;text-transform:uppercase}.wx-sun-time{font-size:1.15rem;font-weight:700;margin-top:.1rem}.wx-section-title{align-self:flex-start;font-size:.72rem;font-weight:700;letter-spacing:1.2px;opacity:.55;padding-left:.25rem;text-transform:uppercase}.wx-forecast-grid{grid-gap:.65rem;display:grid;gap:.65rem;grid-template-columns:repeat(5,1fr);width:100%}.wx-forecast-card{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.16);border-radius:16px;cursor:default;display:flex;flex-direction:column;gap:.3rem;padding:.9rem .5rem;text-align:center;transition:background .18s,box-shadow .18s,-webkit-transform .18s;transition:background .18s,transform .18s,box-shadow .18s;transition:background .18s,transform .18s,box-shadow .18s,-webkit-transform .18s}.wx-forecast-card:hover{background:hsla(0,0%,100%,.2);box-shadow:0 8px 24px rgba(0,0,0,.2);-webkit-transform:translateY(-4px);transform:translateY(-4px)}.wx-forecast-card.today{background:hsla(0,0%,100%,.22);border-color:hsla(0,0%,100%,.35)}.wx-forecast-day{font-size:.72rem;font-weight:700;opacity:.7}.wx-forecast-icon{margin:.15rem 0}.wx-forecast-temp{font-size:1.05rem;font-weight:700}.wx-forecast-desc{font-size:.62rem;opacity:.55;text-transform:capitalize}@media (max-width:520px){.wx-temp{font-size:5.5rem;letter-spacing:-3px}.wx-forecast-grid{gap:.4rem;grid-template-columns:repeat(5,1fr)}.wx-forecast-card{border-radius:12px;padding:.65rem .3rem}.wx-forecast-day{font-size:.65rem}.wx-forecast-temp{font-size:.9rem}.wx-pills{gap:.45rem}.wx-pill{font-size:.75rem;padding:.38rem .7rem}}@media (max-width:380px){.wx-temp{font-size:4.5rem}.wx-forecast-grid{gap:.25rem;grid-template-columns:repeat(5,minmax(0,1fr))}}
/*# sourceMappingURL=main.87384cfe.css.map*/