body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.login-container{align-items:center;background:linear-gradient(135deg,#74b9ff,#0984e3);display:flex;flex-direction:column;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.login-container:before{animation:float 20s ease-in-out infinite;background:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cdefs%3E%3Cpattern id='a' x='0' y='0' width='100' height='100' patternUnits='userSpaceOnUse'%3E%3Ccircle cx='20' cy='20' r='8' fill='rgba(255,255,255,0.1)'/%3E%3Ccircle cx='80' cy='40' r='12' fill='rgba(255,255,255,0.1)'/%3E%3Ccircle cx='40' cy='80' r='10' fill='rgba(255,255,255,0.1)'/%3E%3C/pattern%3E%3C/defs%3E%3Cpath fill='url(%23a)' d='M0 0h100v100H0z'/%3E%3C/svg%3E");bottom:0;content:"";left:0;opacity:.3;position:absolute;right:0;top:0}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.weather-header{margin-bottom:40px;position:relative;text-align:center;z-index:1}.weather-icons{display:flex;gap:20px;justify-content:center;margin-bottom:20px}.weather-icon{animation:bounce 3s ease-in-out infinite;color:#fff;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2))}.weather-icon.sun{animation-delay:0s}.weather-icon.cloud{animation-delay:1s}.weather-icon.wind{animation-delay:2s}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.weather-header h1{color:#fff;font-size:3rem;font-weight:700;margin-bottom:10px;text-shadow:0 4px 8px #0000004d}.weather-header p{color:#ffffffe6;font-size:1.2rem;font-weight:400}.login-form-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:20px;box-shadow:0 20px 40px #0000001a;max-width:450px;padding:40px;position:relative;width:100%;z-index:1}.login-form h2{color:#2d3436;font-size:2rem;font-weight:600;margin-bottom:10px;text-align:center}.login-form p{color:#636e72;font-size:1rem;margin-bottom:30px;text-align:center}.form-group{margin-bottom:25px}.form-group label{color:#2d3436;display:block;font-size:.95rem;font-weight:600;margin-bottom:8px}.form-group input{background:#fff;border:2px solid #e0e0e0;border-radius:12px;font-size:1rem;padding:15px 20px;transition:all .3s ease;width:100%}.form-group input:focus{border-color:#74b9ff;box-shadow:0 0 0 3px #74b9ff1a}.input-with-icon{position:relative}.input-icon{color:#74b9ff;left:15px;position:absolute;top:50%;transform:translateY(-50%);z-index:2}.input-with-icon input{padding-left:50px}.login-btn{background:linear-gradient(135deg,#74b9ff,#0984e3);border-radius:12px;color:#fff;font-size:1.1rem;font-weight:600;margin-top:10px;padding:15px;transition:all .3s ease;width:100%}.login-btn:hover:not(:disabled){box-shadow:0 10px 20px #74b9ff4d;transform:translateY(-2px)}.login-btn:active{transform:translateY(0)}.form-footer{border-top:1px solid #e0e0e0;margin-top:25px;padding-top:20px;text-align:center}.form-footer p{color:#636e72;margin:0}.form-footer .link{color:#74b9ff;font-weight:600;transition:color .3s ease}.form-footer .link:hover{color:#0984e3}.weather-footer{bottom:20px;color:#fffc;font-size:.9rem;position:absolute;text-align:center;z-index:1}@media (max-width:768px){.login-container{padding:15px}.weather-header h1{font-size:2.5rem}.login-form-container{padding:30px 25px}.weather-icons{gap:15px}.weather-icon{height:40px;width:40px}}.dashboard-container{background:#f5f6f7;color:#222;min-height:100vh}.weather-header{background:#fff;border-bottom:1px solid #e6e6e6;justify-content:space-between;padding:16px 20px}.weather-header,.weather-info{align-items:center;display:flex}.weather-info{gap:30px}.weather-main{align-items:center;display:flex;gap:15px}.weather-icon.large{color:#ff3b3f;height:60px;width:60px}.temperature{align-items:baseline;display:flex;gap:5px}.temp-number{font-size:3rem;font-weight:700;line-height:1}.temp-unit{font-size:1.5rem;font-weight:500;opacity:.8}.weather-details{display:flex;flex-direction:column;gap:8px}.weather-detail{align-items:center;display:flex;font-size:.9rem;gap:8px;opacity:.9}.detail-icon{color:#74b9ff;height:16px;width:16px}.user-section{align-items:center;display:flex;gap:15px}.username{font-size:1.1rem;font-weight:500}.logout-btn{align-items:center;background:#fff3;border-radius:50%;color:#fff;display:flex;justify-content:center;padding:10px;transition:all .3s ease}.logout-btn:hover{background:#ffffff4d;transform:scale(1.1)}.dashboard-content{margin:0 auto;max-width:1200px;padding:30px}.news-section{background:#fff;border:1px solid #e6e6e6;border-radius:12px;margin-bottom:24px;padding:20px}.news-section h3{color:#ff3b3f;margin-bottom:16px}.news-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.news-card{background:#fff;border:1px solid #eee;border-radius:10px;box-shadow:0 1px 3px #0000000f;display:flex;flex-direction:column;overflow:hidden}.news-image{height:140px;object-fit:cover;width:100%}.news-content{display:flex;flex-direction:column;gap:6px;padding:12px 14px 14px}.news-meta{display:flex;font-size:12px;justify-content:space-between;opacity:.8}.news-title{font-size:1rem;margin:0}.news-body{font-size:.95rem;margin:0;opacity:.9}.news-link{color:#ff3b3f;font-size:.9rem;font-weight:600}.skeleton{opacity:.7}.skeleton-card{animation:shimmer 1.2s infinite;background:linear-gradient(90deg,#f0f0f0 25%,#e8e8e8 37%,#f0f0f0 63%);border-radius:10px;height:210px}.content-section h2{font-size:2rem;font-weight:600;margin-bottom:30px;text-align:center;text-shadow:0 2px 4px #0003}.search-section{margin-bottom:40px}.search-container{background:#fff;border:1px solid #e6e6e6;border-radius:24px;display:flex;margin:0 auto;max-width:500px;overflow:hidden}.search-container input{background:#0000;border:none;color:#222;flex:1 1;font-size:1rem;padding:15px 20px}.search-container input::placeholder{color:#888}.search-btn{align-items:center;background:#ff3b3f;border:none;color:#fff;display:flex;justify-content:center;padding:15px 20px;transition:all .3s ease}.search-btn:hover:not(:disabled){background:#e5373b}.search-btn:disabled{opacity:.6}.search-results{background:#fff;border:1px solid #e6e6e6;border-radius:12px;margin-bottom:24px;padding:20px}.search-results h3{color:#ff3b3f;font-size:1.3rem;margin-bottom:20px}.search-result{align-items:center;background:#ffffff1a;border-radius:10px;display:flex;justify-content:space-between;margin-bottom:10px;padding:15px;transition:all .3s ease}.search-result:hover{background:#ffffff26}.result-info{display:flex;flex-direction:column;gap:5px}.result-name{font-size:1.1rem;font-weight:600}.result-email{font-size:.9rem;opacity:.8}.add-btn{align-items:center;background:linear-gradient(135deg,#00b894,#00a085);border-radius:20px;color:#fff;display:flex;font-weight:600;gap:8px;padding:10px 20px;transition:all .3s ease}.add-btn:hover{box-shadow:0 5px 15px #00b8944d;transform:translateY(-2px)}.friends-section{background:#fff;border:1px solid #e6e6e6;border-radius:12px;padding:20px 24px}.friends-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.clear-btn{background:#ff6b6be6;border-radius:18px;color:#fff;font-weight:600;padding:8px 14px;transition:all .25s ease}.clear-btn:hover{box-shadow:0 5px 14px #ff6b6b59;transform:translateY(-1px)}.friends-section h3{color:#ff3b3f;font-size:1.3rem;margin-bottom:20px}.no-friends{font-style:italic;opacity:.8;text-align:center}.friends-list{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));padding:6px 2px 2px}.friend-item{align-items:center;background:#ffffff1a;border-radius:12px;cursor:pointer;display:flex;justify-content:space-between;padding:14px 16px;transition:all .25s ease}.friend-item:hover{background:#ffffff26;box-shadow:0 6px 20px #00000026;transform:translateY(-2px)}.friend-info{gap:12px}.friend-avatar,.friend-info{align-items:center;display:flex}.friend-avatar{background:#fff3;border-radius:50%;height:46px;justify-content:center;width:46px}.avatar-icon{color:#74b9ff}.source-avatar{color:#1b2440;font-weight:700;letter-spacing:.5px}.source-initials{color:#1b2440}.friend-details{display:flex;flex-direction:column;gap:6px}.friend-name{font-size:1.1rem;font-weight:600}.friend-status{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.paper-badge{background:#ffffff1f;opacity:.95}.country-pill,.paper-badge{border-radius:12px;font-size:12px;padding:2px 8px}.country-pill{background:#00b8942e;color:#a8f0e4}.friend-actions{gap:10px}.chat-btn,.friend-actions{align-items:center;display:flex}.chat-btn{background:linear-gradient(135deg,#00b894,#00a085);border-radius:18px;color:#fff;font-weight:600;gap:8px;padding:8px 16px;transition:all .25s ease}.chat-btn:hover{box-shadow:0 5px 15px #00b8944d;transform:translateY(-2px)}.correspondent-card .friend-status{font-style:italic}.remove-btn{background:#ff6b6bd9;border-radius:18px;color:#fff;font-weight:600;padding:8px 16px;transition:all .25s ease}.remove-btn:hover{background:#ff6b6b;transform:translateY(-2px)}@media (max-width:768px){.weather-header{text-align:center}.weather-header,.weather-info{flex-direction:column;gap:20px}.weather-details{flex-direction:row;gap:20px}.dashboard-content{padding:20px}.search-container{border-radius:15px;flex-direction:column}.search-container input{border-radius:15px 15px 0 0}.search-btn{border-radius:0 0 15px 15px}.friend-item{flex-direction:column;gap:15px;text-align:center}.friend-actions{justify-content:center;width:100%}}.chat-container{animation:chatFadeIn .6s ease-out;background:#f5f6f7;display:flex;flex-direction:column;height:100vh;min-height:100vh}.chat-header{border-bottom:1px solid #e6e6e6;box-shadow:0 1px 3px #0000000f;gap:12px;padding:calc(8px + env(safe-area-inset-top)) 12px 10px;position:-webkit-sticky;position:sticky;top:0;z-index:20}.back-btn,.chat-header{align-items:center;background:#fff;display:flex}.back-btn{border-radius:50%;color:#ff3b3f;justify-content:center;min-height:38px;min-width:38px;padding:8px;transition:all .3s ease}.back-btn:hover{background:#ffe7e8;transform:scale(1.1)}.chat-info{flex:1 1;position:relative;text-align:center}.chat-info h3{color:#222;font-size:1.05rem;font-weight:600;margin-bottom:2px}.weather-status{color:#666;opacity:.7;position:absolute;right:12px;top:8px}.chat-status{color:#ff3b3f;font-size:.8rem;gap:6px;opacity:.9}.chat-status,.owl-btn{align-items:center;display:flex;justify-content:center}.owl-btn{background:linear-gradient(135deg,gold,#f39c12);border-radius:50%;box-shadow:0 4px 15px #ffd7004d;color:#2d3436;min-height:55px;min-width:55px;padding:15px;position:relative;transition:all .3s ease}.owl-btn:hover{box-shadow:0 6px 20px #ffd70066;transform:scale(1.1)}.owl-btn.decrypted{background:linear-gradient(135deg,#00b894,#00a085);box-shadow:0 4px 15px #00b8944d}.owl-btn.decrypted:hover{box-shadow:0 6px 20px #00b89466}.timer-indicator{align-items:center;animation:pulse 1s ease-in-out infinite;background:#e74c3c;border-radius:50%;color:#fff;display:flex;font-size:10px;height:20px;justify-content:center;position:absolute;right:-5px;top:-5px;width:20px}.puzzle-container{gap:8px}.puzzle-container,.weather{align-items:center;display:flex}.weather{border-radius:50%;box-shadow:0 2px 6px #0000002e;cursor:pointer;font-size:18px;height:36px;justify-content:center;transition:all .3s ease;-webkit-user-select:none;user-select:none;width:36px}.weather:hover{box-shadow:0 4px 12px #00000040;transform:scale(1.1)}.weather.sun{background:gold}.weather.cloud{background:#ecf0f1}.weather.rain{background:#3498db}.weather.completed{outline:2px solid #2ecc71}.weather.cloud.armed{outline:2px dashed #f1c40f}.cow-btn{align-items:center;background:linear-gradient(135deg,#ffeaa7,#fdcb6e);border-radius:50%;box-shadow:0 3px 10px #00000024;color:#2d3436;display:flex;justify-content:center;margin-left:6px;min-height:40px;min-width:40px;padding:10px;transition:transform .2s ease}.cow-btn:disabled{cursor:not-allowed;opacity:.6}.cow-btn:hover:not(:disabled){transform:scale(1.05)}.clear-convo-btn{align-items:center;background:#ffffffe6;border:1px solid #e6e6e6;border-radius:50%;color:#666;display:flex;justify-content:center;margin-left:6px;min-height:40px;min-width:40px;padding:10px;transition:transform .2s ease}.clear-convo-btn:hover{background:#f9f9f9;transform:scale(1.05)}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.chat-main{grid-gap:12px;display:grid;flex:1 1;gap:12px;grid-template-columns:1fr 320px;min-height:0;overflow:hidden;padding:0 12px}.messages-container{display:flex;flex-direction:column;min-height:0;overflow-y:auto;padding:12px 0 140px}.no-messages{align-items:center;color:#ffffffb3;display:flex;font-style:italic;height:100%;justify-content:center;text-align:center}.messages-list{display:flex;flex-direction:column;gap:15px}.messages-list.feed{gap:12px}.article-card{animation:messageSlideIn .4s ease-out;animation-fill-mode:both;background:#fff;border-radius:6px;box-shadow:0 1px 2px #0000000d;color:#222;padding:0 0 8px}.article-image{border-top-left-radius:6px;border-top-right-radius:6px;display:block;height:120px;object-fit:cover;width:100%}.article-meta{display:flex;font-size:11px;justify-content:space-between;opacity:.8;padding:8px 12px 4px}.article-title{font-size:1rem;line-height:1.35;margin:0;padding:0 12px}.article-body{font-size:.9rem;line-height:1.45;margin:6px 0 0;opacity:.9;padding:0 12px 4px}.article-footer{display:flex;font-size:11px;justify-content:space-between;opacity:.8;padding:0 12px 8px}.reply-btn{align-items:center;background:#fff;border:1px solid #e6e6e6;border-radius:14px;color:#ff3b3f;display:inline-flex;gap:6px;padding:4px 8px}.reply-btn:hover{background:#ffe7e8;border-color:#ff3b3f}.article-reply-quote{background:#f5f7fa;border-left:3px solid #e6e6e6;border-radius:6px;color:#333;cursor:pointer;margin:6px 12px 4px;padding:6px 8px}.article-reply-quote .reply-label{color:#888;font-size:10px;margin-right:6px}.article-reply-quote .reply-author{color:#555;font-size:10px}.article-reply-quote .reply-excerpt{color:#444;font-size:11px;margin-top:3px}.reply-preview{background:#fff;border:1px solid #e6e6e6;border-radius:8px;color:#222;left:12px;padding:6px 8px;position:absolute;right:12px;top:6px;width:calc(100% - 24px);z-index:1}.reply-preview-header{align-items:center;color:#555;display:flex;font-size:11px;justify-content:space-between}.reply-preview-body{color:#333;font-size:12px;margin-top:3px}.reply-cancel{background:#0000;color:#ff3b3f;font-size:16px;line-height:1}.reply-cancel:hover{opacity:.8}.message-input-container{animation:inputFadeIn .5s ease-out .8s both;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-top:1px solid #fff3;padding:12px 12px calc(12px + env(safe-area-inset-bottom));position:relative}.message-input-container.has-reply{padding-top:60px}.message-input-row{align-items:center;display:flex;gap:10px}.message-input-container input{background:#fff;border:1px solid #e6e6e6;border-radius:20px;color:#222;flex:1 1;font-size:.95rem;padding:12px 14px;transition:all .3s ease}.message-input-container input::placeholder{color:#888}.message-input-container input:focus{background:#fff;border-color:#ff3b3f}.message-input-container input:disabled{cursor:not-allowed;opacity:.6}.send-btn{align-items:center;background:linear-gradient(135deg,#00b894,#00a085);border-radius:50%;box-shadow:0 3px 12px #00b89447;color:#fff;display:flex;justify-content:center;min-height:42px;min-width:42px;padding:12px;transition:all .3s ease}.send-btn:hover:not(:disabled){box-shadow:0 6px 20px #00b89466;transform:scale(1.1)}.owl-icon{font-size:16px}.send-btn:disabled{cursor:not-allowed;opacity:.6}.bell-btn{align-items:center;background:#fff;border:1px solid #e6e6e6;border-radius:50%;box-shadow:0 1px 3px #00000014;display:flex;height:42px;justify-content:center;width:42px}.bell-btn:hover{background:#f9f9f9}.article-card .thumb{border-radius:6px;height:68px;object-fit:cover;width:90px}.article-card .thumb-wrap{padding:8px 12px 0}.image-overlay{align-items:center;background:#000000b3;display:flex;inset:0;justify-content:center;position:fixed;z-index:50}.image-overlay-inner{max-height:90vh;max-width:92vw;position:relative}.image-overlay-inner img{border-radius:8px;max-height:90vh;max-width:92vw}.image-close{align-items:center;background:#fff;border:1px solid #ddd;border-radius:50%;box-shadow:0 2px 8px #0003;display:flex;height:32px;justify-content:center;position:absolute;right:-10px;top:-10px;width:32px}.news-sidebar{animation:sidebarSlideIn .8s ease-out .3s both;height:calc(100vh - 66px);overflow-y:auto;padding:6px 0 12px;position:-webkit-sticky;position:sticky;top:66px}.news-mini-header{color:#222;font-size:.95rem;font-weight:700;margin:4px 2px 10px}.news-mini-list{display:flex;flex-direction:column;gap:10px}.news-mini-card{grid-gap:10px;background:#fff;border:1px solid #e9e9e9;border-radius:10px;box-shadow:0 1px 2px #0000000a;color:inherit;display:grid;gap:10px;grid-template-columns:80px 1fr;overflow:hidden;text-decoration:none;transition:box-shadow .2s ease,transform .15s ease}.news-mini-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-1px)}.news-mini-card img{border-right:1px solid #f1f1f1;height:64px;object-fit:cover;width:80px}.news-mini-card .mini-content{display:flex;flex-direction:column;gap:4px;padding:8px 10px}.news-mini-card .mini-title{font-size:.9rem;font-weight:700;line-height:1.3}.news-mini-card .mini-desc,.news-mini-card .mini-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.news-mini-card .mini-desc{font-size:.82rem;opacity:.9}.news-mini-card.skeleton{animation:shimmer 1.2s infinite;background:linear-gradient(90deg,#f0f0f0 25%,#e8e8e8 37%,#f0f0f0 63%);border-radius:10px;height:64px}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}@media (max-width:1024px){.chat-main{grid-template-columns:1fr;padding:0 10px}.news-sidebar{display:none}}.chat-loading{align-items:center;animation:loadingPulse 2s ease-in-out infinite;background:linear-gradient(135deg,#74b9ff,#0984e3);color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.chat-loading .loading-spinner{animation:spin 1s ease-in-out infinite;border:3px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:50px;margin-bottom:20px;width:50px}.chat-loading p{font-size:18px;font-weight:500}@media (max-width:768px){.messages-container{padding:10px 10px 120px}.article-image{height:100px}.article-title{font-size:.95rem}.article-body{font-size:.875rem}.article-footer,.article-meta{font-size:10px}.send-btn{min-height:40px;min-width:40px;padding:10px}.message-input-container input{font-size:.9rem;padding:10px 12px}}@media (max-width:420px){.chat-header{gap:10px;padding:calc(6px + env(safe-area-inset-top)) 10px 8px}.back-btn{min-height:34px;min-width:34px}.chat-info h3{font-size:.95rem}.chat-status{font-size:.75rem;gap:4px}.weather{font-size:16px;height:32px;width:32px}.clear-convo-btn,.cow-btn{min-height:36px;min-width:36px;padding:8px}.messages-container{padding:8px}.article-image{height:90px}.article-title{font-size:.9rem}.article-body{font-size:.85rem}.reaction-btn,.reply-btn{padding:2px 6px}}.delete-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.delete-modal{animation:slideUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 40px #00000026;margin:20px;max-width:400px;overflow:hidden;width:90%}.delete-modal-header{border-bottom:1px solid #e6e6e6;padding:24px 24px 16px}.delete-modal-header h3{color:#222;font-size:18px;font-weight:600;margin:0;text-align:center}.delete-modal-body{padding:20px 24px}.delete-modal-body p{color:#666;font-size:14px;line-height:1.5;margin:0;text-align:center}.delete-modal-actions{display:flex;gap:12px;justify-content:center;padding:16px 24px 24px}.delete-cancel-btn{background:#f5f5f5;border:1px solid #e6e6e6;border-radius:8px;color:#666;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.delete-cancel-btn:hover{background:#e9e9e9;border-color:#ccc}.delete-confirm-btn{background:#ff4757;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.delete-confirm-btn:hover{background:#ff3742;box-shadow:0 4px 12px #ff47574d;transform:translateY(-1px)}.message{animation:slideIn .3s ease-out}@keyframes chatFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes inputFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes loadingPulse{0%,to{background:linear-gradient(135deg,#74b9ff,#0984e3)}50%{background:linear-gradient(135deg,#0984e3,#74b9ff)}}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(15px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes sidebarSlideIn{0%{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.typing-indicator{align-items:center;color:#ffffffb3;display:flex;font-style:italic;gap:5px;padding:10px 20px}.typing-dots{display:flex;gap:3px}.typing-dot{animation:typing 1.4s ease-in-out infinite both;background:currentColor;border-radius:50%;height:6px;width:6px}.typing-dot:first-child{animation-delay:-.32s}.typing-dot:nth-child(2){animation-delay:-.16s}@keyframes typing{0%,80%,to{opacity:.5;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.upload-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.upload-modal{animation:slideUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 40px #00000026;margin:20px;max-width:400px;overflow:hidden;width:90%}.upload-modal-header{align-items:center;border-bottom:1px solid #e6e6e6;display:flex;justify-content:space-between;padding:20px 24px}.upload-modal-header h3{color:#222;font-size:18px;font-weight:600;margin:0}.upload-modal-close{align-items:center;background:none;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;padding:0;transition:all .2s ease;width:32px}.upload-modal-close:hover{background:#f5f5f5;color:#333}.upload-modal-body{padding:24px}.upload-options{gap:16px}.upload-option,.upload-options{display:flex;flex-direction:column}.upload-option{align-items:center;gap:8px}.upload-option-btn{align-items:center;background:#f8f9fa;border:2px dashed #4a90e2;border-radius:8px;color:#4a90e2;cursor:pointer;display:flex;font-size:14px;font-weight:500;justify-content:center;min-height:48px;padding:16px 24px;text-align:center;transition:all .2s ease;width:100%}.upload-option-btn:hover{background:#e3f2fd;border-color:#1976d2;color:#1976d2}.paste-instruction{border-style:solid;cursor:default}.paste-instruction,.paste-instruction:hover{background:#e8f5e8;border-color:#66bb6a;color:#2e7d32}.paste-hint{color:#666;font-size:12px;margin:0;text-align:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.image-preview-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.image-preview-modal{animation:slideUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 40px #00000026;margin:20px;max-width:500px;overflow:hidden;width:90%}.image-preview-header{align-items:center;border-bottom:1px solid #e6e6e6;display:flex;justify-content:space-between;padding:20px 24px}.image-preview-header h3{color:#222;font-size:18px;font-weight:600;margin:0}.image-preview-close{align-items:center;background:none;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;padding:0;transition:all .2s ease;width:32px}.image-preview-close:hover{background:#f5f5f5;color:#333}.image-preview-body{background:#f8f9fa;display:flex;justify-content:center;padding:20px}.image-preview-img{border-radius:8px;box-shadow:0 4px 8px #0000001a;max-height:300px;max-width:100%}.image-preview-actions{border-top:1px solid #e6e6e6;display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}.image-preview-cancel{background:#f5f5f5;border:1px solid #e6e6e6;border-radius:8px;color:#666;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.image-preview-cancel:hover:not(:disabled){background:#e9e9e9;border-color:#ccc}.image-preview-confirm{align-items:center;background:#4a90e2;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s ease}.image-preview-confirm:hover:not(:disabled){background:#1976d2}.image-preview-cancel:disabled,.image-preview-confirm:disabled{cursor:not-allowed;opacity:.6}.upload-spinner{animation:spin 1s linear infinite;border:2px solid #fff;border-radius:50%;border-top-color:#0000;height:16px;width:16px}.weather-alert-message{background:linear-gradient(135deg,#fff3e0,#ffcc02)!important;border:2px solid #ff9800!important;box-shadow:0 4px 12px #ff98004d!important}.weather-alert-message .article-title{color:#e65100!important;font-weight:600!important}.weather-alert-message .article-meta{background:#ff98001a!important}.weather-alert-message .article-source{color:#f57c00!important;font-weight:500!important}.notification-overlay{display:flex;flex-direction:column;gap:10px;max-width:350px;pointer-events:none;position:fixed;right:20px;top:20px;width:100%;z-index:2000}.notification-card{animation:slideInRight .3s ease-out;background:#fff;border:1px solid #e1e5e9;border-radius:12px;box-shadow:0 4px 20px #00000026;cursor:pointer;overflow:hidden;pointer-events:auto;transition:all .2s ease}.notification-card:hover{box-shadow:0 6px 25px #0003;transform:translateY(-2px)}.notification-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e1e5e9;display:flex;padding:12px 16px}.notification-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:16px;font-weight:600;height:40px;justify-content:center;margin-right:12px;width:40px}.notification-info{flex:1 1;min-width:0}.notification-sender{color:#1c1e21;font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notification-time{color:#65676b;font-size:12px;margin-top:2px}.notification-close{align-items:center;background:none;border:none;border-radius:50%;color:#65676b;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;height:24px;justify-content:center;margin-left:8px;padding:4px;transition:all .2s ease;width:24px}.notification-close:hover{background:#e4e6ea;color:#1c1e21}.notification-message{word-wrap:break-word;color:#1c1e21;font-size:14px;line-height:1.4;padding:12px 16px}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@media (max-width:480px){.notification-overlay{left:10px;max-width:none;right:10px;top:10px}.notification-card{margin:0}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f6f7;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App,.loading-screen,body{min-height:100vh}.loading-screen{align-items:center;background:#f5f6f7;color:#fff;display:flex;flex-direction:column;justify-content:center}.loading-spinner{animation:spin 1s ease-in-out infinite;border:3px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:50px;margin-bottom:20px;width:50px}@keyframes spin{to{transform:rotate(1turn)}}.loading-screen p{font-size:18px;font-weight:500}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}button{border:none;cursor:pointer;font-family:inherit;outline:none}button:disabled{cursor:not-allowed;opacity:.6}input{border:none;font-family:inherit;outline:none}a{color:inherit;text-decoration:none}button:focus,input:focus{outline:2px solid #ff3b3f;outline-offset:2px}
/*# sourceMappingURL=main.afb946b3.css.map*/