:root{--bg: #f7f8fa;--surface: #ffffff;--surface-low: #f3f3fe;--text: #17202a;--muted: #667085;--border: #e4e7ec;--primary: #2563eb;--primary-dark: #004ac6;--primary-soft: #dbe1ff;--secondary: #d6e0f8;--danger: #dc2626;--success: #16a34a;--warning: #d97706;--pinned: #f59e0b;font-family:Inter,PingFang SC,Microsoft YaHei,system-ui,sans-serif;color:var(--text);background:var(--bg)}*{box-sizing:border-box}body{margin:0;min-width:320px;background:var(--bg)}button,input,textarea,select{font:inherit}button{cursor:pointer;border:0;background:transparent}button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.compose-card input:focus-visible,.compose-card textarea:focus-visible{outline:0}.top-nav{position:fixed;inset:0 0 auto;z-index:50;height:64px;background:var(--surface);border-bottom:1px solid var(--border)}.top-nav__inner{width:min(100% - 64px,1680px);height:100%;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px}.mobile-detail-top{display:none}.brand-row,.top-actions,.desktop-tabs,.post-card__meta,.post-card__stats,.author-line,.detail-actions,.section-title,.comment-title,.comment-foot,.admin-title,.admin-filters{display:flex;align-items:center}.brand{display:grid;gap:2px;justify-items:start;color:var(--primary);line-height:1}.brand span{font-size:22px;font-weight:900;letter-spacing:0}.brand em{color:#64748b;font-size:11px;font-style:normal;font-weight:800;letter-spacing:.02em}.mobile-icon,.mobile-search-panel{display:none}.desktop-tabs{gap:24px;margin-left:32px}.desktop-tabs button{display:inline-flex;align-items:center;gap:6px;color:#475569;padding:20px 0 17px;border-bottom:2px solid transparent}.desktop-tabs button.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:700}.top-actions{gap:12px}.search-box{width:272px;height:40px;padding:0 12px;display:flex;align-items:center;gap:8px;border:1px solid var(--border);background:#f8fafc;border-radius:8px;color:#94a3b8}.search-box input{width:100%;border:0;background:transparent}.icon-button{width:40px;height:40px;display:grid;place-items:center;border-radius:999px;color:#475569}.icon-button:hover,.mobile-icon:hover{background:#f8fafc}.notification-menu,.notification-trigger{position:relative}.notification-trigger.has-unread{color:var(--primary);background:var(--primary-soft)}.notification-badge{position:absolute;top:3px;right:2px;min-width:18px;height:18px;padding:0 5px;display:inline-flex;align-items:center;justify-content:center;color:#fff;background:var(--danger);border:2px solid var(--surface);border-radius:999px;font-size:10px;font-weight:900;line-height:1}.notification-popover{position:absolute;top:calc(100% + 12px);right:0;z-index:80;width:min(360px,calc(100vw - 32px));overflow:hidden;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:0 24px 70px #0f172a2e}.notification-popover__header{padding:14px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid var(--border)}.notification-popover__header>div{display:inline-flex;align-items:center;gap:10px}.notification-popover__header strong{color:var(--text);font-size:15px}.notification-popover__header span{color:var(--muted);font-size:12px;font-weight:800}.notification-popover__header button{border:0;background:transparent;color:var(--primary);font-size:12px;font-weight:900;cursor:pointer}.notification-popover__list{max-height:360px;overflow-y:auto}.notification-popover__list button,.notification-popover__list p{margin:0;padding:12px 16px;width:100%;display:grid;gap:4px;text-align:left;border:0;border-bottom:1px solid #f1f5f9;background:transparent;cursor:pointer}.notification-popover__list button:hover{background:#f8fafc}.notification-popover__list button:last-child,.notification-popover__list p:last-child{border-bottom:0}.notification-popover__list strong{color:var(--primary);font-size:12px;letter-spacing:.04em}.notification-popover__list span,.notification-empty{color:#475569;font-size:13px;line-height:1.5}.page-shell{width:min(100% - 64px,1680px);margin:0 auto;padding:96px 0 48px}.feed-layout,.detail-layout{display:grid;grid-template-columns:minmax(720px,1fr) minmax(300px,360px);gap:32px}.feed-main,.detail-main{min-width:0}@media(min-width:901px){body:has(.feed-layout){overflow:hidden}.feed-layout{height:100vh;padding-top:96px;padding-bottom:24px}.feed-main{height:100%;min-height:0;overflow-y:auto;padding-right:8px;overscroll-behavior:contain;scrollbar-gutter:stable;scrollbar-color:transparent transparent;scrollbar-width:thin;transition:scrollbar-color .18s ease}.feed-main::-webkit-scrollbar{width:8px}.feed-main::-webkit-scrollbar-thumb{background:transparent;border-radius:999px}.feed-main:hover,.feed-main:focus-within{scrollbar-color:#cbd5e1 transparent}.feed-main:hover::-webkit-scrollbar-thumb,.feed-main:focus-within::-webkit-scrollbar-thumb{background:#cbd5e1}.side-panel,.detail-side{position:sticky;top:96px;max-height:calc(100vh - 120px)}.side-panel{overflow-y:auto;overscroll-behavior:contain;padding-right:4px;scrollbar-gutter:stable;scrollbar-color:transparent transparent;scrollbar-width:thin;transition:scrollbar-color .18s ease}.side-panel::-webkit-scrollbar{width:8px}.side-panel::-webkit-scrollbar-thumb{background:transparent;border-radius:999px}.side-panel:hover,.side-panel:focus-within{scrollbar-color:#cbd5e1 transparent}.side-panel:hover::-webkit-scrollbar-thumb,.side-panel:focus-within::-webkit-scrollbar-thumb{background:#cbd5e1}.detail-side{overflow:hidden}}.notice-bar{display:flex;align-items:center;gap:12px;padding:12px 16px;margin-bottom:24px;color:#eef2ff;background:var(--primary);border-radius:8px}.notice-bar p{flex:1;margin:0;font-size:14px;line-height:1.5}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:8px}.segmented{display:flex;gap:4px;padding:4px;background:#f1f5f9;border-radius:8px}.segmented button{padding:7px 16px;display:inline-flex;align-items:center;gap:6px;color:var(--muted);border-radius:6px;font-size:14px}.segmented button.active{background:var(--surface);color:var(--primary);font-weight:700;box-shadow:0 1px 4px #0f172a14}.primary-action{min-height:40px;padding:0 18px;display:inline-flex;align-items:center;justify-content:center;gap:8px;color:#fff;background:var(--primary);border-radius:8px;font-weight:700}.primary-action:disabled,.publish-pill:disabled{cursor:not-allowed;opacity:.45}.post-list{display:grid;gap:16px}.pull-refresh{height:0;overflow:hidden;display:none;align-items:center;justify-content:center;gap:8px;color:#64748b;font-size:13px;font-weight:900;transition:height .18s ease,color .18s ease}.pull-refresh svg{transition:transform .18s ease}.pull-refresh.is-ready{color:var(--primary)}.pull-refresh.is-ready svg{transform:rotate(180deg)}.pull-refresh.is-refreshing svg{animation:spin-refresh .8s linear infinite}@keyframes spin-refresh{to{transform:rotate(360deg)}}.feed-end{padding:18px;color:var(--muted);text-align:center;background:#ffffffb8;border:1px dashed var(--border);border-radius:10px;font-size:13px;font-weight:700}.search-status{margin-bottom:12px;padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:12px;color:#475569;background:#fff;border:1px solid var(--border);border-radius:12px;font-size:13px;font-weight:800}.search-status span{min-width:0;display:inline-flex;align-items:center;gap:7px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-status button{flex:0 0 auto;color:var(--primary);font-weight:900}.post-card{padding:24px;background:var(--surface);border:1px solid var(--border);border-radius:8px;transition:border-color .18s ease,transform .18s ease}.post-card:hover{border-color:#bfdbfe;transform:translateY(-1px)}.post-card__meta{flex-wrap:wrap;gap:8px;margin-bottom:12px;color:var(--muted);font-size:13px}.pin-tag,.private-tag,.identity{padding:3px 8px;border-radius:999px;font-size:12px;font-weight:800}.pin-tag{color:#fff;background:var(--pinned)}.private-tag{color:#7d2d00;background:#ffdbcd}.identity.guest{color:#3d475a;background:var(--secondary)}.identity.user{color:var(--primary);background:var(--primary-soft)}.identity.admin{color:#93000a;background:#ffdad6}.post-card h2{margin:0 0 8px;color:var(--text);font-size:20px;line-height:1.3}.post-card p{margin:0 0 16px;color:#434655;line-height:1.6}.post-thumb{width:min(100%,520px);max-height:260px;margin-bottom:16px;object-fit:cover;display:block;border-radius:10px}.post-card__stats{gap:20px;color:var(--muted);font-size:13px;font-weight:700}.post-card__stats span,.post-card__stats button{display:inline-flex;align-items:center;gap:6px;color:inherit;font-weight:inherit}.post-card__stats button{padding:0;border-radius:999px}.post-card__stats button:not(:disabled):active{transform:scale(.94)}.post-card__stats .liked{color:var(--primary)}.post-card__stats .liked svg{fill:currentColor}.side-panel,.detail-side{display:grid;align-content:start;gap:24px}.panel-block{padding:24px;background:var(--surface);border:1px solid var(--border);border-radius:12px}.panel-block h3{margin:0 0 8px}.panel-block p{margin:0 0 16px;color:var(--muted);font-size:13px;line-height:1.5}.panel-block button{width:100%;height:40px;display:inline-flex;align-items:center;justify-content:center;gap:7px;color:var(--primary);border:1px solid var(--primary);border-radius:8px;font-weight:700}.identity-panel{display:grid;gap:18px}.identity-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.identity-summary{display:flex;align-items:center;gap:12px;min-width:0}.identity-summary strong{min-width:0;overflow:hidden;color:var(--text);font-size:18px;line-height:1.3;text-overflow:ellipsis;white-space:nowrap}.logout-button{color:var(--danger)!important;border-color:#fecaca!important;background:#fff7f7}.panel-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.panel-title-row h3{margin:0;display:inline-flex;align-items:center;gap:8px}.panel-title-row span{color:var(--muted);font-size:12px;font-weight:700}.hot-discussion-list{display:grid;gap:6px}.hot-discussion-item{width:100%;min-height:56px;height:auto!important;padding:8px 6px;display:grid;grid-template-columns:26px minmax(0,1fr);align-items:start;gap:10px;color:var(--text)!important;border:0!important;border-radius:8px;text-align:left;justify-items:stretch;justify-content:stretch}.hot-discussion-item:hover{background:#f8fafc}.hot-rank{width:22px;height:22px;margin-top:1px;display:grid;place-items:center;color:#64748b;background:#f1f5f9;border-radius:6px;font-size:12px;font-weight:800}.hot-rank--top{color:#fff;background:var(--pinned)}.hot-discussion-content{width:100%;min-width:0;display:grid;gap:5px;justify-items:start;text-align:left}.hot-discussion-content strong{width:100%;overflow:hidden;color:var(--text);font-size:14px;line-height:1.35;text-overflow:ellipsis;white-space:nowrap}.hot-discussion-content em{display:inline-flex;align-items:center;gap:4px;color:var(--muted);font-size:12px;font-style:normal}.rule-row{display:flex;align-items:flex-start;gap:10px;color:#434655!important}.rule-row svg{color:var(--success);flex:0 0 auto}.back-link{display:inline-flex;align-items:center;gap:8px;margin-bottom:16px;color:var(--muted);font-weight:600}.detail-card,.comments,.comment-box,.comment-item{background:var(--surface);border:1px solid var(--border);border-radius:12px}.detail-card{overflow:hidden}.detail-header,.rich-content,.detail-actions{padding:32px}.detail-header{padding-bottom:0}.detail-header h1{margin:0 0 16px;font-size:28px;line-height:1.3;letter-spacing:0}.author-line{gap:12px}.author-line>div:nth-child(2),.author-summary div{display:flex;flex-direction:column}.author-line span,.author-summary span{color:var(--muted);font-size:13px}.author-line button{margin-left:auto;color:var(--muted)}.avatar{width:40px;height:40px;display:grid;place-items:center;flex:0 0 auto;color:var(--primary);background:var(--primary-soft);border-radius:999px;font-weight:800;overflow:hidden}.avatar img{width:100%;height:100%;display:block;object-fit:cover}.avatar.small{width:32px;height:32px;font-size:12px}.avatar.tiny{width:26px;height:26px;font-size:11px}.avatar.large{width:48px;height:48px}.rich-content{display:grid;gap:16px;color:#434655;font-size:16px;line-height:1.7}.rich-content p{margin:0}.rich-content figure{margin:8px 0;overflow:hidden;border-radius:12px}.rich-content img{width:100%;aspect-ratio:16 / 9;object-fit:cover;display:block}.detail-actions{gap:12px;border-top:1px solid var(--border)}.detail-actions button{min-height:42px;padding:0 18px;display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border);border-radius:8px;color:#434655;font-weight:700}.detail-actions .liked{color:#fff;background:var(--primary);border-color:var(--primary)}.detail-actions .share{margin-left:auto;border-color:transparent}.detail-actions .danger-action{color:var(--danger);background:#fef2f2;border-color:#fecaca}.comments{margin-top:24px;overflow:hidden;background:#fff;border-color:#edf2f7}.section-title{justify-content:space-between;padding:18px 22px 8px;border-bottom:0}.section-title h2{margin:0;display:inline-flex;align-items:center;gap:8px;font-size:18px;letter-spacing:-.01em}.section-title span{display:inline-flex;align-items:center;color:var(--muted);font-size:13px}.comment-sort-tabs{display:inline-flex;gap:6px;padding:3px;background:#f6f7f9;border:0;border-radius:999px}.comment-sort-tabs button{min-height:30px;padding:0 12px;color:var(--muted);border-radius:999px;font-size:13px;font-weight:800}.comment-sort-tabs button.active{color:#fff;background:#1f2937;box-shadow:0 8px 18px #0f172a1a}.comment-box{display:grid;grid-template-columns:auto 1fr auto;gap:12px;margin:10px 22px 8px;padding:12px;background:#f7f8fa;border:0;border-radius:20px}.comment-box textarea{min-height:56px;border:0;border-radius:16px;resize:vertical;padding:12px;background:#fff;transition:border-color .18s ease,box-shadow .18s ease}.comment-box textarea:focus{border-color:#11182747;box-shadow:0 0 0 4px #0f172a0f;outline:0}.comment-editor{display:grid;gap:10px}.comment-visibility-row{display:grid;grid-template-columns:150px 1fr;gap:10px}.comment-visibility-row select,.comment-visibility-row input,.admin-settings textarea{min-height:40px;border:1px solid #e2e8f0;border-radius:12px;padding:0 12px;background:#fff}.admin-settings textarea{min-height:92px;padding:12px;resize:vertical}.comment-box button{align-self:end;min-height:40px;padding:0 16px;display:inline-flex;align-items:center;gap:6px;color:#fff;background:#ff2442;border-radius:999px;font-weight:800}.comment-list{display:grid}.comment-item{display:grid;grid-template-columns:auto minmax(0,1fr) 42px;align-items:start;gap:11px;padding:18px 22px;border:0;border-top:1px solid #f4f5f7;border-radius:0;background:transparent}.comment-item--reply{padding-top:10px;padding-left:112px;border-top:0}.comment-item--reply .avatar{margin-top:2px}.comment-content{min-width:0}.comment-title{justify-content:flex-start;gap:8px}.comment-title strong{color:#6b7280;font-size:13px;font-weight:800}.comment-item p{margin:4px 0 7px;color:#111827;font-size:15px;line-height:1.62;overflow-wrap:anywhere}.reply-prefix{color:#6b7280;font-weight:800}.comment-visibility-badge{width:fit-content;margin:2px 0 7px;padding:2px 7px;display:inline-flex;color:#9a3412;background:#fff7ed;border:1px solid #fed7aa;border-radius:999px;font-size:11px;font-weight:800}.reply-editor{margin-top:9px;padding:10px;display:grid;gap:10px;background:#fff;border:1px solid #edf2f7;border-radius:14px}.reply-editor textarea{width:100%;min-height:68px;padding:10px 12px;resize:vertical;border:1px solid #e2e8f0;border-radius:12px;background:#fff}.reply-editor__actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.reply-editor__actions select,.reply-editor__actions button{min-height:34px;padding:0 12px;display:inline-flex;align-items:center;gap:6px;border:1px solid #e2e8f0;border-radius:999px;font-weight:800}.reply-editor__actions button:last-child{color:#fff;background:#ff2442;border-color:#ff2442}.reply-editor__actions button:disabled{cursor:not-allowed;opacity:.5}.comment-foot{gap:10px;color:#9ca3af;font-size:12px;line-height:1.4}.comment-foot button{color:#6b7280;font-weight:800}.comment-like{min-width:34px;padding-top:3px;display:grid;justify-items:center;gap:3px;color:#9ca3af;font-size:11px;font-weight:800;border-radius:999px}.comment-like svg{width:18px;height:18px;stroke-width:1.9}.comment-like.liked{color:#ff2442}.comment-like.liked svg{fill:currentColor}.comment-like span{line-height:1}.author-summary{display:flex;align-items:center;gap:12px;margin:18px 0}.mobile-comment-bar{display:none}.compose-page{min-height:100vh;padding:88px 16px 72px}.compose-header{position:fixed;inset:0 0 auto;z-index:55;height:56px;padding:0 16px;display:flex;align-items:center;justify-content:space-between;background:var(--surface);border-bottom:1px solid var(--border)}.compose-header h1{margin:0;font-size:20px}.publish-pill{min-width:72px;height:34px;display:inline-flex;align-items:center;justify-content:center;gap:6px;color:#fff;background:var(--primary);border-radius:999px;font-weight:800}.compose-card{max-width:800px;margin:0 auto;padding:32px;background:var(--surface);border:1px solid var(--border);border-radius:12px}.compose-intro{margin-bottom:22px;padding-bottom:18px;border-bottom:1px solid #eef2f7}.compose-intro span{display:inline-flex;margin-bottom:8px;color:var(--primary);font-size:12px;font-weight:900;letter-spacing:.08em}.compose-intro p{margin:0;color:#475569;font-size:14px;line-height:1.6}.title-input-frame{width:100%;padding:10px 14px 12px;border:1px solid transparent;border-bottom-color:#e5e7eb;border-radius:10px;background:linear-gradient(#fff,#fff) padding-box,linear-gradient(135deg,transparent,transparent) border-box;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease,transform .2s ease}.title-input-frame:focus-within{border-color:#2563eb61;background:linear-gradient(#fff,#fff) padding-box,linear-gradient(135deg,#2563eb8c,#93c5fd3d) border-box;box-shadow:0 12px 32px #2563eb1a,0 0 0 4px #2563eb14;transform:translateY(-1px)}.title-input{width:100%;padding:0;border:0;background:transparent;font-size:28px;font-weight:700}.compose-counter{margin-top:10px;display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--muted);font-size:12px;font-weight:700}.compose-counter strong{color:#475569;font-size:12px}.compose-counter.is-warning,.compose-counter.is-warning strong{color:#b45309}.editor-frame{margin:24px 0;border:1px solid var(--border);border-radius:8px;overflow:hidden;background:#fff;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}.editor-frame:focus-within{border-color:#2563eb6b;box-shadow:0 16px 40px #2563eb1a,0 0 0 4px #2563eb14;transform:translateY(-1px)}.editor-toolbar{height:42px;padding:0 8px;display:flex;align-items:center;gap:4px;background:#f8fafc;border-bottom:1px solid var(--border)}.editor-toolbar button{min-width:32px;height:32px;display:grid;place-items:center;border-radius:6px;color:#475569;font-weight:800}.editor-frame textarea{width:100%;min-height:280px;padding:16px;border:0;background:transparent;resize:vertical;line-height:1.6}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.uploaded-images{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin:16px 0 24px}.uploaded-images figure{position:relative;margin:0;overflow:hidden;border:1px solid var(--border);border-radius:8px;background:var(--surface-low)}.uploaded-images img{width:100%;aspect-ratio:16 / 9;display:block;object-fit:cover}.uploaded-images button{position:absolute;right:8px;bottom:8px;min-height:30px;padding:0 10px;color:#fff;background:#0f172ab8;border-radius:6px;font-size:12px;font-weight:700}.full-input,.admin-filters select,.admin-filters input,.login-card input{width:100%;height:42px;padding:0 12px;border:1px solid var(--border);border-radius:8px;background:#fff}.full-input{margin-top:12px}.compose-actions{margin-top:24px;padding-top:24px;display:flex;justify-content:flex-end;border-top:1px solid var(--border)}.profile-page{max-width:820px;margin:0 auto;padding:88px 16px}.profile-header{display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center;padding:28px 16px;background:var(--surface);border-bottom:1px solid var(--border)}.profile-avatar-editor{display:grid;gap:10px;justify-items:center}.profile-avatar{width:64px;height:64px}.profile-header .avatar-edit-button{height:32px;padding:0 10px;gap:5px;color:#0f5132;background:#ecfdf5;border-color:#bbf7d0;border-radius:999px;font-size:12px;white-space:nowrap}.profile-header .avatar-edit-button:disabled{cursor:not-allowed;opacity:.55}.profile-header h1{display:inline;margin:0 8px 0 0;font-size:20px}.profile-header span{padding:3px 7px;color:#596377;background:var(--secondary);border-radius:4px;font-size:10px;font-weight:800}.profile-header p{margin:6px 0 0;color:var(--muted);font-size:13px}.profile-actions{display:flex;align-items:center;gap:10px}.profile-header button{height:40px;padding:0 16px;display:inline-flex;align-items:center;gap:7px;color:var(--primary);background:var(--surface-low);border:1px solid #c3c6d7;border-radius:8px;font-weight:700}.profile-stats{display:grid;grid-template-columns:repeat(3,1fr);padding:20px 0;background:var(--surface);border-bottom:1px solid var(--border)}.profile-stats div{display:grid;gap:5px;text-align:center}.profile-stats div+div{border-left:1px solid #f1f5f9}.profile-stats span{color:var(--muted);font-size:13px}.profile-tabs{position:sticky;top:64px;z-index:10;display:grid;grid-template-columns:repeat(3,1fr);background:var(--surface);border-bottom:1px solid var(--border)}.profile-tabs button{height:48px;display:inline-flex;align-items:center;justify-content:center;gap:7px;color:var(--muted);font-weight:700;border-bottom:2px solid transparent}.profile-tabs button.active{color:var(--primary);border-bottom-color:var(--primary)}.profile-list{display:grid;gap:16px;padding-top:16px}.profile-post-card{position:relative}.profile-post-card .post-card{padding-right:112px}.profile-post-delete{position:absolute;top:18px;right:18px;min-height:36px;padding:0 12px;display:inline-flex;align-items:center;gap:6px;color:var(--danger);background:#fef2f2;border:1px solid #fecaca;border-radius:999px;font-size:13px;font-weight:800}.profile-activity-card{display:grid;gap:12px;padding:18px;background:var(--surface);border:1px solid var(--border);border-radius:8px}.profile-activity-card--clickable{cursor:pointer;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}.profile-activity-card--clickable:hover{border-color:#bfdbfe;box-shadow:0 12px 28px #2563eb1a;transform:translateY(-1px)}.profile-activity-card p{margin:0;color:var(--text);font-size:15px;line-height:1.65}.profile-activity-card__meta,.profile-activity-card__stats{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13px}.profile-activity-card__meta span{min-width:0;overflow:hidden;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.profile-activity-card__meta time{margin-left:auto;white-space:nowrap}.profile-liked-post{display:grid;gap:8px}.admin-login-page{min-height:100vh;padding:48px 16px;display:grid;place-items:center;background:#f8fafc}.admin-login-card{width:min(100%,420px);padding:32px;display:grid;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 18px 44px #0f172a14}.admin-login-icon{width:52px;height:52px;display:grid;place-items:center;color:var(--primary);background:var(--primary-soft);border-radius:999px}.admin-login-card h1,.admin-login-card p{margin:0}.admin-login-card p{color:var(--muted);line-height:1.55}.admin-login-card label{display:grid;gap:8px;font-weight:700}.admin-login-card input,.admin-settings input{width:100%;height:44px;padding:0 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.admin-layout{display:grid;grid-template-columns:256px 1fr;min-height:100vh}.admin-side{position:fixed;top:0;bottom:0;left:0;width:256px;padding:32px 8px;background:#f8fafc;border-right:1px solid var(--border)}.admin-side h2,.admin-side p{margin-left:16px}.admin-side p{margin-bottom:28px;color:var(--muted);font-size:11px;letter-spacing:.12em;text-transform:uppercase}.admin-side button{width:100%;height:48px;padding:0 16px;display:flex;align-items:center;gap:12px;color:#64748b;border-radius:8px;font-weight:700}.admin-side button.active{color:var(--primary);background:#eff6ff}.admin-main{grid-column:2;padding:32px}.admin-title{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px}.admin-title h1{margin:0;font-size:28px}.admin-title p{margin:6px 0 0;color:var(--muted)}.admin-message{margin:-8px 0 18px;min-height:40px;padding:0 14px;display:inline-flex;align-items:center;gap:8px;color:#166534;background:#ecfdf5;border:1px solid #bbf7d0;border-radius:10px;font-weight:800}.admin-filters{display:grid;grid-template-columns:1fr 1fr 1fr auto auto;gap:12px;margin-bottom:24px;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:12px}.admin-filters button{min-height:42px;padding:0 14px;display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid var(--border);border-radius:8px;font-weight:700}.status-pill{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;color:#166534;background:#ecfdf5;border:1px solid #bbf7d0;border-radius:999px;font-size:12px;font-weight:800}.status-pill.deleted{color:#991b1b;background:#fef2f2;border-color:#fecaca}.status-pill.disabled{color:#9f1239;background:#fff1f2;border-color:#fecdd3}.confirm-backdrop{position:fixed;inset:0;z-index:120;padding:24px;display:grid;place-items:center;background:#0f172a6b;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.confirm-dialog{width:min(100%,420px);padding:26px;display:grid;gap:18px;background:var(--surface);border:1px solid rgba(254,202,202,.9);border-radius:18px;box-shadow:0 28px 80px #0f172a47;animation:confirm-in .18s ease both}.confirm-icon{width:48px;height:48px;display:grid;place-items:center;color:var(--danger);background:#fef2f2;border:1px solid #fecaca;border-radius:16px}.confirm-dialog h2{margin:0;color:var(--text);font-size:22px}.confirm-dialog p{margin:8px 0 0;color:var(--muted);line-height:1.65}.confirm-actions{display:flex;justify-content:flex-end;gap:10px}.confirm-actions button{min-height:40px;padding:0 16px;display:inline-flex;align-items:center;gap:7px;border-radius:10px;font-weight:800}.confirm-actions button:first-child{color:var(--text);background:#f8fafc;border:1px solid var(--border)}.confirm-actions button.danger{color:#fff;background:var(--danger)}@keyframes confirm-in{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.table-wrap{overflow-x:auto;background:var(--surface);border:1px solid var(--border);border-radius:12px}table{width:100%;border-collapse:collapse;min-width:860px}th,td{padding:16px 18px;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle;font-size:14px}th{color:var(--muted);background:#f8fafc;font-size:12px;letter-spacing:.04em}.table-title,.table-author{display:flex;align-items:center;gap:10px}.table-title svg{color:var(--pinned)}.table-title strong,.table-author strong{display:block;max-width:340px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.table-title span,.table-author em{color:var(--muted);font-size:12px;font-style:normal}.table-author>span{width:32px;height:32px;display:grid;place-items:center;color:#596377;background:var(--secondary);border-radius:999px;font-weight:800}td button{display:inline-flex;align-items:center;gap:4px;margin-right:10px;color:var(--primary);font-weight:700}td button.danger{color:var(--danger)}.admin-settings{width:min(100%,620px);padding:24px;display:grid;gap:20px;background:var(--surface);border:1px solid var(--border);border-radius:12px}.admin-settings h2,.admin-settings p{margin:0}.admin-settings h2,.field-label,.rules h3,.panel-block h3,.compose-header h1{display:inline-flex;align-items:center;gap:8px}.field-hint{color:var(--muted);font-size:12px;font-weight:700}.field-hint.danger{color:var(--danger)}.admin-settings p,.settings-message{color:var(--muted);line-height:1.55}.settings-meta{display:grid;grid-template-columns:96px 1fr;gap:10px 16px;padding:16px;background:#f8fafc;border:1px solid var(--border);border-radius:8px}.settings-meta span{color:var(--muted)}.admin-settings label{display:grid;gap:8px;font-weight:700}.identity-note{margin:0;color:var(--muted);font-size:13px}.notification-list{display:grid;gap:10px}.notification-list p{margin:0;padding:10px 0;border-top:1px solid var(--border);color:var(--muted);line-height:1.45}.notification-list strong{margin-right:8px;color:var(--primary)}.login-page{min-height:100vh;padding:0;display:grid;place-items:center;overflow:hidden;background:radial-gradient(circle at 14% 12%,rgba(245,158,11,.2),transparent 26%),radial-gradient(circle at 86% 16%,rgba(125,211,252,.32),transparent 30%),radial-gradient(circle at 48% 92%,rgba(254,243,199,.7),transparent 34%),linear-gradient(135deg,#fff7ed,#f2f8f1 48%,#eaf6ff)}.login-page:before{content:"";position:fixed;inset:-20%;pointer-events:none;background:linear-gradient(rgba(15,23,42,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(15,23,42,.035) 1px,transparent 1px);background-size:54px 54px;-webkit-mask-image:radial-gradient(circle at center,#000 0%,transparent 72%);mask-image:radial-gradient(circle at center,#000 0%,transparent 72%);animation:login-grid-drift 18s linear infinite}.login-stage{position:relative;z-index:1;width:min(1120px,calc(100vw - 40px));min-height:min(720px,calc(100vh - 40px));display:grid;grid-template-columns:minmax(0,1.1fr) 430px;align-items:stretch;color:#fffaf0;animation:login-rise .7s ease both;filter:drop-shadow(0 28px 70px rgba(96,76,45,.18))}.login-poster{position:relative;padding:clamp(32px,6vw,72px);display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;border:1px solid rgba(255,255,255,.55);border-right:0;border-radius:28px 0 0 28px;background:linear-gradient(180deg,#2c362b05,#293524b8 72%),url(/login-hero.png) center / cover}.login-poster:after{content:"";position:absolute;inset:auto 8% 10% auto;width:180px;height:180px;border-radius:999px;background:#ffd5805c;filter:blur(38px);animation:login-orb 6s ease-in-out infinite alternate}.login-kicker{width:max-content;margin-bottom:18px;padding-bottom:8px;border-bottom:1px solid rgba(251,191,36,.72);color:#fbbf24;letter-spacing:.22em;font-size:12px;font-weight:800}.login-poster h1{position:relative;z-index:1;margin:0;max-width:8em;font-size:clamp(54px,8vw,96px);line-height:.95;letter-spacing:-.06em}.login-poster p{position:relative;z-index:1;width:min(520px,100%);margin:24px 0 0;color:#fff7edc7;font-size:17px;line-height:1.7}.login-poster .login-slogan{width:max-content;margin:12px 0 20px auto;padding:7px 12px;color:#fffbeb;background:#0f172a5c;border:1px solid rgba(251,191,36,.5);border-radius:999px;font-size:15px;font-weight:900;letter-spacing:.08em}.login-proof{position:relative;z-index:1;margin-top:34px;display:flex;flex-wrap:wrap;gap:10px}.login-proof span{padding:9px 12px;display:inline-flex;align-items:center;gap:7px;color:#fff7edd1;border:1px solid rgba(255,255,255,.18);border-radius:999px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-size:13px}.login-card{padding:clamp(28px,4vw,44px);display:grid;align-content:center;gap:22px;color:#152018;background:linear-gradient(180deg,#ffffffc7,#fffaf0f5),#fffaf0;border:1px solid rgba(255,255,255,.9);border-left:0;border-radius:0 28px 28px 0;box-shadow:0 30px 80px #78583029}.login-card__header{display:grid;gap:8px}.login-card__header span{color:#a16207;letter-spacing:.18em;font-size:12px;font-weight:800}.login-card__header h2{margin:0;color:#172018;font-size:32px;letter-spacing:-.04em}.login-card label{display:grid;gap:8px;color:#293524;font-weight:800}.login-card input{height:50px;border-color:#78583029;border-radius:14px;background:#ffffffe0;font-size:15px;transition:border-color .18s ease,box-shadow .18s ease,background .18s ease}.login-card input:focus{outline:0;border-color:#d97706;background:#fff;box-shadow:0 0 0 4px #f59e0b29}.login-tabs,.login-subtabs{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:6px;background:#78583014;border-radius:16px}.login-tabs button,.login-subtabs button{min-height:44px;display:inline-flex;align-items:center;justify-content:center;gap:7px;color:#293524a3;border-radius:12px;font-weight:800;transition:color .18s ease,background .18s ease,transform .18s ease}.login-tabs button:hover,.login-subtabs button:hover{transform:translateY(-1px)}.login-tabs button.active,.login-subtabs button.active{color:#172018;background:#fff;box-shadow:0 10px 28px #7858301f}.login-panel{display:grid;gap:16px}.login-help{margin:-4px 0 0;color:#6b705c;line-height:1.6;font-size:13px}.login-submit{min-height:52px;padding:0 18px;display:inline-flex;align-items:center;justify-content:center;gap:8px;color:#21160a;background:#f59e0b;border-radius:999px;font-weight:900;box-shadow:0 18px 34px #d9770647;transition:transform .18s ease,box-shadow .18s ease,opacity .18s ease}.login-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 22px 42px #d977065c}.login-submit:disabled{cursor:not-allowed;opacity:.48}.login-current-user{padding:12px 14px;color:#596377;background:#d977061a;border:1px solid rgba(217,119,6,.16);border-radius:12px;font-size:13px}@keyframes login-rise{0%{opacity:0;transform:translateY(18px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes login-grid-drift{0%{transform:translateZ(0)}to{transform:translate3d(54px,54px,0)}}@keyframes login-orb{0%{transform:translateZ(0) scale(1)}to{transform:translate3d(-36px,-28px,0) scale(1.15)}}.mobile-bottom{display:none}.empty-state{padding:48px 20px;display:grid;place-items:center;text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:12px}.state-block{padding:28px 20px;display:grid;gap:8px;place-items:center;text-align:center;color:var(--muted);background:var(--surface);border:1px solid var(--border);border-radius:12px}.state-block h2{margin:0;color:var(--text);font-size:18px}.state-block p{margin:0}.state-block button{min-height:36px;margin-top:8px;padding:0 16px;color:var(--primary);border:1px solid var(--primary);border-radius:8px;font-weight:700}.toast{position:fixed;top:76px;right:24px;z-index:90;max-width:min(360px,calc(100vw - 32px));padding:12px 16px;display:inline-flex;align-items:center;gap:10px;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 12px 30px #0f172a24;text-align:left;font-weight:700}.toast span{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;border-radius:999px}.toast--success{border-color:#bbf7d0;background:#f0fdf4}.toast--success span{color:#fff;background:var(--success)}.toast--error{border-color:#fecaca;background:#fff7f7}.toast--error span{color:#fff;background:var(--danger)}button:disabled{cursor:not-allowed;opacity:.55}.empty-state h2{margin:16px 0 4px}.empty-state p{margin:0 0 20px;color:var(--muted)}@media(max-width:900px){html,body,#root{width:100%;overflow-x:hidden}body:has(.feed-layout){overflow:auto}.top-nav{height:56px}.top-nav__inner{width:100%;padding:0 16px}.top-nav--detail .top-nav__inner{display:none}.top-nav--detail .mobile-detail-top{height:56px;padding:0 8px;display:grid;grid-template-columns:48px 1fr 48px;align-items:center}.mobile-detail-top strong{text-align:center;font-size:20px}.mobile-detail-top button{width:44px;height:44px;display:grid;place-items:center;color:var(--primary);border-radius:999px}.brand{color:var(--text)}.mobile-icon{width:40px;height:40px;display:grid;place-items:center;color:var(--primary);border-radius:999px}.mobile-icon.active{color:#fff;background:var(--primary)}.mobile-search-panel{position:fixed;top:62px;left:8px;right:8px;z-index:80;padding:8px;display:flex;align-items:center;gap:8px;background:#fffffff5;border:1px solid var(--border);border-radius:16px;box-shadow:0 18px 45px #0f172a24;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.mobile-search-panel .mobile-search-box{flex:1;width:auto;height:42px;padding:0 12px;display:flex;background:#f8fafc;border-radius:12px}.mobile-search-panel input{font-size:15px}.mobile-search-panel>button{height:42px;padding:0 12px;color:var(--primary);background:#eff6ff;border-radius:12px;font-size:13px;font-weight:900}.desktop-tabs,.top-actions>.search-box,.side-panel,.detail-side{display:none}.top-actions{gap:4px}.page-shell{width:100%;max-width:none;margin:0;padding:64px 8px 90px}.feed-layout,.detail-layout{display:block;width:100%;height:auto;padding-bottom:88px}.feed-main,.detail-main{width:100%;min-width:0}.feed-main{height:auto;overflow:visible;padding-right:0}.pull-refresh{display:flex}.notice-bar{margin:0 0 8px;padding:12px 16px;border-radius:14px;background:#eff6ff;color:#596377;border:1px solid #dbeafe}.notice-bar svg{color:var(--primary)}.toolbar{margin:0 0 8px;padding:12px 16px;gap:10px;border-width:1px;border-radius:14px}.search-status{margin:0 0 8px;border-radius:14px}.segmented{flex:1;min-width:0}.segmented button{flex:1;justify-content:center;min-width:0;padding:7px 8px;white-space:nowrap}.toolbar .feed-compose-action{width:44px;height:44px;min-height:44px;flex:0 0 auto;padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:0;line-height:0;color:#fff;background:var(--primary);border-radius:999px;overflow:hidden}.toolbar .feed-compose-action svg{width:20px;height:20px;flex:0 0 auto}.toolbar .feed-compose-action span{display:none}.post-list{gap:8px}.post-card{padding:16px;border-width:1px;border-radius:14px}.profile-post-card .post-card{padding-right:86px}.profile-post-delete{top:14px;right:14px;min-height:32px;padding:0 10px}.post-card:hover{transform:none}.post-card h2{font-size:20px}.post-thumb{width:100%;max-height:210px;border-radius:8px}.back-link{display:none}.detail-card,.comments{border-width:1px;border-radius:14px}.detail-header,.rich-content,.detail-actions{padding:20px 16px}.detail-header h1{font-size:20px}.detail-actions{display:none}.section-title{padding:16px 14px 8px;gap:12px}.section-title h2{font-size:17px}.comment-sort-tabs button{min-height:28px;padding:0 10px;font-size:12px}.comment-box{display:none}.comment-item{grid-template-columns:auto minmax(0,1fr) 36px;gap:9px;padding:16px 14px}.comment-item--reply{padding-top:8px;padding-left:58px}.comment-title strong{font-size:12px}.comment-item p{font-size:14px}.comment-foot{gap:10px}.comment-like{min-width:30px;padding-top:2px}.comment-like svg{width:17px;height:17px}.reply-editor{padding:9px}.reply-editor__actions{justify-content:flex-start}.reply-editor__actions select{width:100%}.mobile-comment-bar{position:fixed;inset:auto 0 0;z-index:65;height:78px;padding:10px 12px;display:flex;align-items:center;gap:10px;background:#fffffff5;border-top:1px solid #eef2f7;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.mobile-comment-input{flex:1;min-width:0;min-height:58px;padding:7px 12px;display:flex;flex-direction:column;justify-content:center;gap:5px;background:#f5f6f8;border-radius:18px}.mobile-comment-visibility{position:relative;display:inline-flex;align-items:center;gap:5px;color:#64748b;font-size:11px;font-weight:800}.mobile-visibility-trigger{width:auto!important;height:22px!important;padding:0 8px!important;display:inline-flex!important;align-items:center;gap:4px;color:#64748b;background:#fff!important;border:1px solid #dbe3ef;border-radius:999px;font-size:11px;font-weight:800}.mobile-visibility-menu{position:absolute;left:0;bottom:calc(100% + 8px);z-index:75;min-width:112px;padding:6px;display:grid;gap:4px;background:#fff;border:1px solid #dbe3ef;border-radius:12px;box-shadow:0 14px 36px #0f172a29}.mobile-visibility-menu button{width:100%!important;height:30px!important;padding:0 10px!important;display:flex!important;align-items:center;justify-content:flex-start;color:#64748b;background:transparent;border-radius:8px;font-size:12px;font-weight:800}.mobile-visibility-menu button.active{color:#fff;background:var(--primary)}.mobile-comment-bar input{width:100%;border:0;background:transparent}.mobile-comment-bar button{width:40px;height:40px;display:grid;place-items:center;color:var(--primary);border-radius:999px}.mobile-comment-bar button.liked{color:#fff;background:var(--primary)}.mobile-comment-bar button.liked svg{fill:currentColor}.compose-page{padding:64px 10px 90px;background:radial-gradient(circle at 20% 0%,rgba(37,99,235,.08),transparent 28%),var(--bg)}.compose-card{min-height:auto;padding:18px 14px 20px;border:1px solid #e3e8f2;border-radius:18px;box-shadow:0 18px 48px #0f172a0f}.compose-intro{margin-bottom:16px;padding:2px 2px 14px}.compose-intro p{font-size:13px}.title-input{font-size:22px;line-height:1.35}.title-input-frame{padding:13px 14px;border-color:#e2e8f0;border-radius:14px;background:#fbfdff}.editor-frame{margin:18px 0 0;border-width:1px;border-radius:16px}.editor-toolbar{height:44px;padding:0 10px;background:#f8fafc}.editor-toolbar button{border-radius:10px}.editor-frame textarea{min-height:300px;padding:16px 14px;font-size:15px}.compose-counter{margin-top:12px;padding:0 2px}.editor-frame+.compose-counter{margin-top:12px}.uploaded-images{grid-template-columns:repeat(auto-fill,minmax(132px,1fr));gap:10px;margin:18px 0 22px}.uploaded-images figure{border-radius:12px}.compose-actions{display:none}.profile-page{width:100%;max-width:none;margin:0;padding:64px 8px 90px;overflow-x:hidden}.profile-header{grid-template-columns:auto minmax(0,1fr);gap:14px;padding:18px 14px;align-items:start;border:1px solid var(--border);border-radius:16px;box-shadow:0 10px 26px #0f172a0a}.profile-header>div:nth-child(2){min-width:0}.profile-avatar-editor{max-width:82px}.profile-avatar{width:56px;height:56px}.profile-header h1{display:block;margin:0 0 6px;overflow-wrap:anywhere;font-size:18px;line-height:1.25}.profile-header p{overflow-wrap:anywhere}.profile-actions{grid-column:1 / -1;width:100%;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.profile-header button{width:100%;justify-content:center;padding:0 10px;white-space:nowrap}.profile-stats{margin-top:8px;border:1px solid var(--border);border-radius:16px;overflow:hidden}.profile-tabs{top:56px;margin-top:8px;border:1px solid var(--border);border-radius:16px;overflow:hidden}.profile-tabs button{min-width:0;gap:5px;font-size:13px}.profile-list{width:100%;padding:8px 0 0;gap:8px}.profile-list .state-block{margin:0;border-radius:16px}.profile-post-card{overflow:hidden;border:1px solid var(--border);border-radius:16px;background:var(--surface)}.profile-post-card .post-card{padding:16px 72px 16px 16px;border-width:0;border-radius:16px}.profile-post-delete{top:12px;right:12px;min-height:30px;padding:0 9px;font-size:12px}.profile-activity-card,.profile-liked-post{margin:0;border-width:1px;border-radius:16px;overflow:hidden}.profile-activity-card{padding:16px}.profile-activity-card p{overflow-wrap:anywhere}.profile-activity-card__meta,.profile-activity-card__stats{min-width:0}.profile-activity-card__meta svg,.profile-activity-card__stats svg{flex:0 0 auto}.profile-activity-card__meta time{flex:0 0 auto;max-width:96px;overflow:hidden;text-overflow:ellipsis}.profile-liked-post .post-card{border-width:1px 0 0;border-radius:0}.admin-layout{display:block;padding:0 0 32px}.admin-side{position:sticky;top:0;z-index:40;width:100%;padding:14px 12px;display:flex;align-items:center;gap:8px;overflow-x:auto}.admin-side h2,.admin-side p{display:none}.admin-side button{width:auto;min-width:max-content;height:40px;padding:0 12px}.admin-main{padding:16px}.admin-title{align-items:flex-start}.admin-filters{grid-template-columns:1fr}.login-page{min-height:100svh;padding:18px;overflow:auto;place-items:stretch}.login-stage{width:100%;min-height:auto;grid-template-columns:1fr}.login-poster{min-height:260px;padding:28px;border-right:1px solid rgba(255,255,255,.14);border-radius:24px 24px 0 0}.login-poster h1{font-size:58px}.login-poster p{font-size:14px}.login-proof{margin-top:18px}.login-card{padding:24px;border-radius:0 0 24px 24px}.login-card__header h2{font-size:26px}.mobile-bottom{position:fixed;inset:auto 0 0;z-index:70;height:64px;display:flex;justify-content:space-around;align-items:center;background:var(--surface);border-top:1px solid var(--border)}.mobile-bottom button{width:76px;height:52px;display:grid;place-items:center;gap:2px;color:#64748b;border-radius:8px;font-size:11px}.mobile-bottom button span{display:none}.mobile-bottom button.active{color:var(--primary);background:#eff6ff}.toast{top:64px;right:12px;left:12px;max-width:none}}
