*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:#fff;color:#111}.app{height:100vh;display:flex;flex-direction:column}.topbar{position:fixed;top:0;left:0;right:0;height:64px;background:#fff;border-bottom:1px solid #e5e5e5;z-index:50}.topbar-inner{height:64px;display:grid;grid-template-columns:260px minmax(0,720px) auto;align-items:center;padding:0 24px;gap:16px}.logo{width:260px;display:flex;align-items:center;gap:8px}.logo-img{height:43px;width:auto;display:block}.topbar-center{position:absolute;left:260px;right:260px;display:flex;justify-content:center;pointer-events:none}.content-rail{max-width:550px;width:100%;pointer-events:auto}.search{width:100%;padding:12px 16px;border-radius:999px;font-size:14px;outline:none;border:1px solid #2563eb;box-shadow:0 0 0 .1px #aec7ff,0 0 0 2px #709dff2e;transition:border-color .15s ease,box-shadow .15s ease}.search:focus{border-color:#d1d5db;box-shadow:none}.search:hover:not(:focus){box-shadow:0 0 0 .3px #2563eb,0 0 0 .5px #2563eb38}.topbar-actions{grid-column:3;justify-self:end;display:flex;gap:12px;z-index:1}.topbar-actions button{height:36px;padding:0 22px;min-width:96px;border-radius:999px;border:1px solid #e5e7eb;background:#fafafa;font-size:14px;font-weight:600;line-height:1;cursor:pointer;transition:background .15s ease,border-color .15s ease;display:inline-flex;align-items:center;justify-content:center}.topbar-actions button:hover{background:#f3f4f6;border-color:#d1d5db}.topbar-actions button:active{background:#e5e7eb}.topbar-actions button.primary{background:#2563eb;border-color:#2563eb;color:#fff}.topbar-actions button.primary:hover{background:#1d4ed8}.menu-btn{display:none;width:36px;height:36px;padding:0;margin-right:8px;border:none;background:none;color:#111827;font-size:24px;line-height:1;cursor:pointer;align-items:center;justify-content:center}.sidebar{position:fixed;top:64px;left:0;width:260px;height:calc(100vh - 64px);background:#fff;border-right:1px solid #e6e6e6;padding:24px 0;overflow-y:auto;z-index:40;transition:transform .25s ease;display:flex;flex-direction:column}.sidebar-footer{margin-top:auto;padding:24px 20px 16px;font-size:12px;color:#9ca3af;line-height:1.6}.sidebar-footer a{color:inherit;text-decoration:none}.sidebar-footer a:hover{text-decoration:underline}.about{margin:0 16px 16px;padding:14px 16px;background:#f7f8fa;border-radius:14px;border:1px solid #e6e8eb;color:#4b5563;line-height:1.55}.divider{height:1px;margin:14px 20px;background:linear-gradient(to right,#00000014,#00000008)}.sidebar h4{padding:12px 20px 6px;margin:0;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#7a7a7a;display:flex;justify-content:space-between;cursor:pointer}.chevron{transition:transform .15s ease}.chevron.open{transform:rotate(180deg)}.nav-group{padding-bottom:8px}.sidebar button:hover{background:#f6f7f8}.sidebar button.active{background:#eef2ff;color:#2563eb;font-weight:600}.sidebar button.active:hover{background:#e0e7ff}.sidebar button{width:calc(100% - 24px);margin:2px 12px;padding:10px 16px;background:none;border:none;text-align:left;font-size:14px;color:#444;cursor:pointer;border-radius:10px;transition:background .15s ease,color .15s ease}.content{margin-top:64px;height:calc(100vh - 64px);overflow-y:auto}.feed{padding:32px 0}.feed-inner{max-width:720px;margin:0 auto;padding:0 24px;display:flex;flex-direction:column;gap:0}.feed-toolbar{max-width:720px;margin:0 auto 16px;padding:0 24px;display:flex;justify-content:flex-start;gap:12px;align-items:center}.feed-toolbar button:not(.refresh-btn):not(.country-trigger){height:34px;padding:0 14px;border-radius:999px;border:1px solid #e5e7eb;background:#fafafa;font-size:14px;cursor:pointer}.feed-toolbar button:hover{background:#f3f4f6}.refresh-btn{-webkit-appearance:none;appearance:none;box-sizing:border-box;width:40px;height:40px;padding:0;border-radius:50%;border:1px solid #e5e7eb;background:#fff;color:#111827;display:inline-flex;align-items:center;justify-content:center;font-size:16px}.refresh-btn:hover{background:#f9fafb;transform:rotate(90deg);transition:transform .2s ease}.filter-pill{-webkit-appearance:none;appearance:none;display:inline-flex;align-items:center;justify-content:flex-start;box-sizing:border-box;height:40px;padding:0 34px 0 14px;border-radius:999px;border:1px solid #e5e7eb;background-color:#fff;color:#111827;font-size:14px;line-height:1;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236b7280' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}.country-filter{position:relative}.country-trigger{min-width:180px;text-align:left}.country-dropdown{position:absolute;top:calc(100% + 8px);left:0;width:260px;background:#fff;border:1px solid #e5e7eb;border-radius:14px;box-shadow:0 12px 30px #00000014;z-index:70;overflow:hidden}.country-search{width:100%;border:none;border-bottom:1px solid #e5e7eb;padding:12px 14px;font-size:14px;outline:none}.country-options{max-height:260px;overflow-y:auto;padding:4px;scroll-behavior:smooth}.country-option{padding:9px 12px;border-radius:8px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-size:14px;color:#374151;transition:background .12s ease}.country-option:hover{background:#f9fafb}.country-option.active{background:#eef2ff;color:#2563eb;font-weight:600}.country-option small{color:#9ca3af;font-size:12px}.country-empty{padding:12px;font-size:13px;color:#6b7280;text-align:center}.caret{font-size:12px;opacity:.6}.date-picker{-webkit-appearance:none;appearance:none;box-sizing:border-box;height:40px;min-width:140px;padding:0 12px;border-radius:999px;border:1px solid #e5e7eb;background:#fff;color:#111827;-webkit-text-fill-color:#111827;font-size:14px;line-height:1}.date-picker-text{font-variant-numeric:tabular-nums;letter-spacing:.02em}.date-picker-text:focus{outline:none;border-color:#d1d5db;box-shadow:none}.date-picker-text::placeholder{color:#9ca3af;letter-spacing:.02em}.date-picker-text::-webkit-text-fill-color{color:#111827;-webkit-text-fill-color:#111827}.date-picker::-webkit-date-and-time-value{text-align:left}.date-picker::-webkit-calendar-picker-indicator{opacity:.7;cursor:pointer}.filter-pill:hover,.date-picker:hover,.refresh-btn:hover{background:#f9fafb}.date-picker::placeholder{color:#9ca3af}.date-filter{position:relative;flex:0 0 auto}.date-picker-hint{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#9ca3af;font-size:14px;line-height:1;pointer-events:none;font-variant-numeric:tabular-nums;letter-spacing:.02em}.post{position:relative;padding:18px 16px;margin:0;background:transparent;border-bottom:1px solid #e5e7eb;color:#111827}.post:before{content:"";position:absolute;inset:4px 0;border-radius:12px;background:transparent;transition:background .12s ease;z-index:-1}.post:hover:before{background:#f9fafb}.feed-inner .post:first-child{border-top:1px solid #e5e7eb}.rank{font-size:13px;font-weight:600;color:#2563eb}.post h3{margin:0 0 10px;font-size:16.5px;font-weight:600;color:#111827}.post p{margin:0 0 14px;font-size:15px;line-height:1.6;color:#1f2937}.post small{color:#6b7280;font-size:12.5px;line-height:1.4}.post-footer{margin-top:20px;display:flex;justify-content:space-between;align-items:flex-end;gap:16px}.votes{display:inline-flex;align-items:center;gap:8px;padding:4px 8px;background:#f1f5f9;border-radius:999px}.votes button{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;padding:0;background:transparent;border:none;border-radius:999px;cursor:pointer;color:#6b7280;transition:background .15s ease,transform .08s ease,color .15s ease}.votes button:hover{background:#0000000f;color:#2563eb}.votes span{font-size:12px;font-weight:800;line-height:1;min-width:18px;text-align:center;color:#374151}.votes .upvote,.votes .downvote{color:#6b7280}.votes button:disabled{opacity:.4;cursor:not-allowed}.vote-icon{width:19px;height:19px;display:inline-block;background-repeat:no-repeat;background-position:center;background-size:contain}.vote-icon.up{background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 5l-5.5 5.5h3.5v8h4v-8h3.5L12 5z' fill='%236b7280'/%3E%3C/svg%3E")}.vote-icon.down{background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 19l5.5-5.5h-3.5v-8h-4v8H6.5L12 19z' fill='%236b7280'/%3E%3C/svg%3E")}.votes button.voted .vote-icon.up{background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 5l-5.5 5.5h3.5v8h4v-8h3.5L12 5z' fill='%232563eb'/%3E%3C/svg%3E")}.votes button.voted .vote-icon.down{background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 19l5.5-5.5h-3.5v-8h-4v8H6.5L12 19z' fill='%232563eb'/%3E%3C/svg%3E")}.votes button:active{transform:scale(.92)}.modal-backdrop{position:fixed;inset:0;background:#0f172a8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center}.modal{width:100%;max-width:640px;background:#fff;border-radius:18px;padding:24px;box-shadow:0 40px 80px #00000059;display:flex;flex-direction:column;gap:16px}.modal h3{margin:0;font-size:18px}.modal textarea{min-height:140px;resize:vertical;padding:12px 14px;font-size:14px;border-radius:12px;border:1px solid #d1d5db}.modal input,.modal select{padding:10px 12px;font-size:14px;border-radius:10px;border:1px solid #d1d5db}.modal textarea:focus,.modal input:focus,.modal select:focus{outline:none;border-color:#2563eb}.modal .actions{display:flex;justify-content:flex-end;gap:12px}.modal .actions button{padding:10px 18px;border-radius:999px;border:1px solid #e5e7eb;background:#f3f4f6;font-weight:600;cursor:pointer}.modal .actions button.primary{background:#2563eb;border-color:#2563eb;color:#fff}.modal .actions button.primary:hover{background:#1d4ed8}@media(max-width:640px){.modal{max-width:none;height:100%;border-radius:0}}.toast.success{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:110;background:#16a34a;color:#fff;padding:12px 18px;border-radius:999px;font-size:14px;font-weight:600;box-shadow:0 10px 30px #00000040}.toast.error{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:110;background:#dc2626;color:#fff;padding:12px 18px;border-radius:999px;font-size:14px;font-weight:600;box-shadow:0 10px 30px #00000040}.feed-loading{display:flex;justify-content:center;align-items:center;padding:80px 0}.spinner{width:36px;height:36px;border-radius:50%;border:3px solid rgba(37,99,235,.2);border-top-color:#2563eb;animation:spin .8s linear infinite}.refresh-btn:disabled{opacity:.5;cursor:default}@keyframes spin{to{transform:rotate(360deg)}}.load-more{margin:24px auto 0;padding:10px 22px;border-radius:999px;border:1px solid #e5e7eb;background:#fff;font-size:14px;font-weight:600;cursor:pointer}.load-more:hover{background:#f3f4f6}.load-more:disabled{opacity:.5;cursor:default}.end-message{margin:24px auto 0;font-size:13px;color:#6b7280;text-align:center}@media(max-width:1250px){.feed-toolbar{flex-wrap:nowrap;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;scrollbar-width:none}.feed-toolbar::-webkit-scrollbar{display:none}.feed-toolbar>*{flex:0 0 auto}.country-trigger,.country-dropdown,.country-option{touch-action:manipulation}.sidebar{transform:translate(-100%);box-shadow:8px 0 24px #0000001f}.sidebar.open{transform:translate(0)}.topbar{height:128px}.topbar-inner{height:128px;display:grid;grid-template-columns:1fr auto;grid-template-rows:48px 56px;align-items:start;padding:8px 12px 16px;gap:8px 12px}.logo-img{display:block;height:46px;width:auto;margin-left:-14px}.content-rail{width:100%;max-width:660px;margin:0 auto}.search{max-width:660px}.menu-btn{display:inline-flex}.feed-toolbar:has(.country-filter.open){overflow-x:visible}.logo{grid-column:1;grid-row:1;width:auto}.topbar-actions{grid-column:2;grid-row:1;justify-self:end}.topbar-center{grid-column:1 / -1;grid-row:2;position:static;left:auto;right:auto;width:100%;display:flex;justify-content:center;pointer-events:auto}.content{margin-top:128px;height:calc(100vh - 128px)}.sidebar{top:128px;height:calc(100vh - 128px)}}
