.modal-overlay[data-v-36783bc2]{position:fixed;display:flex;top:0;right:0;bottom:0;left:0;align-items:center;justify-content:center;padding:18px;background:#0000007a;z-index:1000}.modal-content[data-v-36783bc2]{position:relative;width:360px;max-width:100%;padding:32px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow-md)}.modal-close[data-v-36783bc2]{position:absolute;top:12px;right:12px;width:28px;height:28px;font-size:20px;line-height:1;color:var(--muted);cursor:pointer;background:none;border:1px solid var(--line);border-radius:var(--radius-sm)}.modal-close[data-v-36783bc2]:hover{color:var(--text);background:var(--surface-soft)}.modal-content h2[data-v-36783bc2]{margin:0 0 10px;font-size:22px;text-align:center}.modal-eyebrow[data-v-36783bc2]{margin:0 0 8px;color:var(--brand-strong);font-size:13px;font-weight:800;text-align:center}.modal-message[data-v-36783bc2]{margin:0 0 22px;color:var(--muted);font-size:14px;line-height:1.7;text-align:center}.modal-form[data-v-36783bc2]{display:grid;gap:14px}.form-group[data-v-36783bc2]{margin:0}.form-group input[data-v-36783bc2]{width:100%;padding:10px 12px;font-size:14px;border:1px solid var(--line);border-radius:var(--radius-sm);outline:none;background:var(--surface);color:var(--text);box-sizing:border-box}.form-group input[data-v-36783bc2]:focus{border-color:var(--brand)}.form-error[data-v-36783bc2]{margin:0 0 12px;color:#dc3545;font-size:13px;text-align:center}.submit-btn[data-v-36783bc2]{width:100%;padding:10px;font-size:14px;font-weight:600;color:#fff;cursor:pointer;background:var(--brand);border:none;border-radius:var(--radius-sm)}.submit-btn[data-v-36783bc2]:hover:not(:disabled){background:var(--brand-strong)}.submit-btn[data-v-36783bc2]:disabled{opacity:.6;cursor:not-allowed}.form-footer[data-v-36783bc2]{margin:16px 0 0;text-align:center;color:var(--muted);font-size:14px}.form-footer button[data-v-36783bc2]{color:var(--brand);cursor:pointer;background:none;border:none;font-size:14px}.form-footer button[data-v-36783bc2]:hover{text-decoration:underline}.toast-container[data-v-9ec6322b]{position:fixed;top:24px;left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}.toast[data-v-9ec6322b]{display:flex;align-items:center;gap:10px;min-width:240px;max-width:420px;padding:12px 16px;border-radius:var(--radius-md);box-shadow:0 4px 16px #00000026;pointer-events:auto;font-size:14px;font-weight:500}.toast.success[data-v-9ec6322b]{color:#fff;background:#10b981}.toast.error[data-v-9ec6322b]{color:#fff;background:#ef4444}.toast.warning[data-v-9ec6322b]{color:#fff;background:#f59e0b}.toast.info[data-v-9ec6322b]{color:#fff;background:#3b82f6}.toast-icon[data-v-9ec6322b]{flex-shrink:0;font-size:16px;font-weight:700}.toast-message[data-v-9ec6322b]{flex:1;line-height:1.4}.toast-close[data-v-9ec6322b]{flex-shrink:0;width:20px;height:20px;padding:0;margin-left:4px;font-size:16px;line-height:1;color:inherit;cursor:pointer;background:#fff3;border:none;border-radius:var(--radius-sm);transition:background-color .15s}.toast-close[data-v-9ec6322b]:hover{background:#ffffff4d}.toast-enter-active[data-v-9ec6322b]{animation:toast-in-9ec6322b .25s ease-out}.toast-leave-active[data-v-9ec6322b]{animation:toast-out-9ec6322b .2s ease-in}@keyframes toast-in-9ec6322b{0%{opacity:0;transform:translateY(-16px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toast-out-9ec6322b{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-8px) scale(.95)}}#nprogress{pointer-events:none}#nprogress .bar{background:#29d;position:fixed;z-index:1031;top:0;left:0;width:100%;height:2px}#nprogress .peg{display:block;position:absolute;right:0;width:100px;height:100%;box-shadow:0 0 10px #29d,0 0 5px #29d;opacity:1;-webkit-transform:rotate(3deg) translate(0px,-4px);-ms-transform:rotate(3deg) translate(0px,-4px);transform:rotate(3deg) translateY(-4px)}#nprogress .spinner{display:block;position:fixed;z-index:1031;top:15px;right:15px}#nprogress .spinner-icon{width:18px;height:18px;box-sizing:border-box;border:solid 2px transparent;border-top-color:#29d;border-left-color:#29d;border-radius:50%;-webkit-animation:nprogress-spinner .4s linear infinite;animation:nprogress-spinner .4s linear infinite}.nprogress-custom-parent{overflow:hidden;position:relative}.nprogress-custom-parent #nprogress .spinner,.nprogress-custom-parent #nprogress .bar{position:absolute}@-webkit-keyframes nprogress-spinner{0%{-webkit-transform:rotate(0deg)}to{-webkit-transform:rotate(360deg)}}@keyframes nprogress-spinner{0%{transform:rotate(0)}to{transform:rotate(360deg)}}:root{--bg: #ffffff;--surface: #ffffff;--surface-soft: #f5f6f8;--surface-muted: #eceef2;--text: #2c3e50;--text-strong: #1a2535;--muted: #7f8fa4;--muted-light: #aab4c4;--line: #e8eaed;--line-strong: #d0d5dd;--brand: #2563eb;--brand-strong: #1d4ed8;--brand-soft: #eff6ff;--brand-hover: #dbeafe;--accent: #e53e3e;--gold: #d4a017;--success: #059669;--warning: #d97706;--info: #0ea5e9;--primary: var(--brand);--primary-strong: var(--brand-strong);--error: var(--accent);--border: var(--line);--bg-secondary: #f7f9fb;--bg-tertiary: #edf0f4;--shadow: 0 1px 4px rgba(0, 0, 0, .07);--shadow-md: 0 4px 12px rgba(0, 0, 0, .09);--shadow-soft: 0 6px 20px rgba(0, 0, 0, .07);--header-shadow: 0 1px 0 var(--line), 0 2px 8px rgba(0, 0, 0, .05);--radius-lg: 10px;--radius-md: 8px;--radius-sm: 6px;--layout-max-width: 1440px;--layout-sidebar-width: 330px;--layout-reading-width: 860px;--layout-admin-sidebar-width: 248px;--layout-editor-sidebar-width: 320px;--layout-gutter: 24px}*,*:before,*:after{box-sizing:border-box}html{min-width:320px;overflow-y:scroll}body{margin:0;color:var(--text);background:var(--bg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,Helvetica Neue,Arial,sans-serif;font-size:14px;line-height:1.6;letter-spacing:0}body.mobile-search-open{overflow:hidden}a{color:inherit;text-decoration:none}button,input{font:inherit}img{display:block;max-width:100%}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;white-space:nowrap;border:0;clip:rect(0,0,0,0)}.site-header{position:sticky;top:0;z-index:100;background:linear-gradient(180deg,var(--surface) 0%,var(--surface-soft) 100%);border-bottom:1px solid var(--line);box-shadow:var(--header-shadow)}.header-inner{display:grid;grid-template-columns:auto auto minmax(260px,1fr) auto;gap:20px;align-items:center;max-width:var(--layout-max-width);min-height:60px;padding:0 var(--layout-gutter);margin:0 auto}.brand{display:inline-flex;gap:8px;align-items:center;font-weight:800}.brand-mark{display:inline-grid;width:32px;height:32px;color:#fff;font-size:14px;font-weight:900;background:linear-gradient(135deg,var(--brand),var(--brand-strong));border-radius:var(--radius-sm);place-items:center;box-shadow:0 2px 6px #2563eb4d}.brand-name{color:var(--text-strong);font-size:17px;font-weight:700;letter-spacing:0}.main-nav{display:flex;gap:0;align-items:center}.main-nav a{position:relative;padding:0 12px;line-height:60px;color:#555;font-size:14px;font-weight:500;border-radius:0;transition:color .15s}.main-nav a:hover,.main-nav a.active,.main-nav a.router-link-active{color:var(--brand)}.main-nav a.active:after,.main-nav a.router-link-active:after{position:absolute;right:0;bottom:0;left:0;height:2px;content:"";background:var(--brand)}.search-box{display:grid;grid-template-columns:minmax(100px,1fr) auto;align-items:center;min-width:0;overflow:hidden;background:var(--surface);border:1px solid var(--line-strong);border-radius:var(--radius-md);transition:border-color .15s,box-shadow .15s}.search-box:focus-within{border-color:var(--brand);box-shadow:0 0 0 3px #2563eb1a}.search-box input{min-width:0;padding:8px 12px;color:var(--text);font-size:13px;background:transparent;border:0;outline:0}.search-box button{height:100%;padding:0 16px;color:#fff;font-size:13px;cursor:pointer;background:var(--brand);border:0;border-left:1px solid var(--brand);transition:background .15s}.search-box button:hover{background:var(--brand-strong)}.header-actions{display:flex;gap:10px;align-items:center;white-space:nowrap}.text-link{padding:4px 8px;color:#555;font-size:14px;font-weight:500;border-radius:var(--radius-sm);transition:color .15s}.text-link:hover{color:var(--brand)}.text-button{padding:0;color:#555;cursor:pointer;background:transparent;border:0;font-size:14px}.text-button:hover{color:var(--brand)}.user-chip{display:inline-flex;gap:6px;align-items:center;padding:4px 10px 4px 6px;background:transparent;border:1px solid var(--line);border-radius:var(--radius-md);cursor:pointer;font-size:13px;font-weight:500;color:var(--text);max-width:160px;transition:border-color .15s,background .15s}.user-chip span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-chip:hover,.user-chip[aria-expanded=true]{border-color:var(--brand);background:var(--brand-soft);color:var(--brand)}.user-chip{transition:border-color .15s,background .15s,color .15s}.user-chip img{width:24px;height:24px;flex-shrink:0;object-fit:cover;border-radius:50%;border:1px solid var(--line)}.user-menu{position:relative}.user-menu-trigger-group{display:inline-flex;align-items:center;gap:4px}.user-home-link:focus-visible{outline:2px solid var(--brand);outline-offset:2px}.user-menu-panel{position:absolute;top:calc(100% + 4px);right:0;left:0;z-index:200;min-width:140px;padding:6px 0;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:var(--shadow-md);overflow:hidden}.user-menu-item{display:flex;align-items:center;width:100%;min-height:38px;padding:0 14px;color:var(--text);font-size:13px;font-weight:500;text-align:left;cursor:pointer;background:transparent;border:0;border-radius:0;transition:background .1s}.user-menu-item:hover{background:var(--surface-soft);color:var(--text-strong)}.user-menu-item-danger{color:var(--accent);border-top:1px solid var(--line);margin-top:2px;padding-top:2px}.user-menu-item-danger:hover{background:#fff5f5;color:var(--accent)}.primary-action{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:0 16px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;background:linear-gradient(135deg,var(--brand),var(--brand-strong));border:1px solid var(--brand);border-radius:var(--radius-md);box-shadow:0 2px 6px #2563eb40;transition:filter .15s,box-shadow .15s}.primary-action:hover{filter:brightness(1.06);box-shadow:0 4px 10px #2563eb4d}.primary-action:disabled,button:disabled{opacity:.56;cursor:not-allowed}.primary-action.block{width:100%}.mobile-search-toggle{display:none;align-items:center;justify-content:center;width:36px;height:36px;padding:0;cursor:pointer;background:transparent;border:1px solid var(--line);border-radius:var(--radius-md);color:var(--text);transition:border-color .15s,background .15s}.mobile-search-toggle:hover{border-color:var(--brand);background:var(--brand-soft);color:var(--brand)}.mobile-search-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0006}.mobile-search-panel{position:fixed;top:0;left:0;right:0;z-index:201;padding:10px 14px;background:var(--surface);border-bottom:1px solid var(--line);box-shadow:0 2px 12px #0000001a}.mobile-search-form{display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:center}.mobile-search-cancel{padding:0 4px;color:var(--text);font-size:14px;cursor:pointer;background:transparent;border:0;white-space:nowrap}.mobile-search-cancel:hover{color:var(--brand)}.mobile-search-input{min-width:0;padding:8px 12px;color:var(--text);font-size:14px;background:var(--surface-soft);border:1px solid var(--line-strong);border-radius:var(--radius-md);outline:0;transition:border-color .15s,box-shadow .15s}.mobile-search-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #2563eb1a}.mobile-search-submit{padding:8px 16px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;background:var(--brand);border:0;border-radius:var(--radius-md);white-space:nowrap;transition:background .15s}.mobile-search-submit:hover{background:var(--brand-strong)}.mobile-menu-toggle{display:none;flex-direction:column;gap:4px;align-items:center;justify-content:center;width:36px;height:36px;padding:0;cursor:pointer;background:transparent;border:1px solid var(--line);border-radius:var(--radius-md)}.mobile-menu-toggle .hamburger-line{display:block;width:18px;height:2px;background:var(--text);border-radius:0;transition:transform .15s,opacity .15s}.mobile-menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#0006}.mobile-menu-drawer{position:fixed;top:0;right:0;bottom:0;z-index:101;display:grid;grid-template-rows:auto 1fr auto;width:min(300px,80vw);padding:16px;background:var(--surface);box-shadow:-4px 0 16px #0000001f;transform:translate(100%);transition:transform .2s ease;overflow-y:auto}.mobile-menu-drawer.open{transform:translate(0)}.mobile-menu-header{display:flex;justify-content:flex-end;margin-bottom:12px}.mobile-menu-close{width:32px;height:32px;font-size:20px;line-height:1;color:var(--muted);cursor:pointer;background:transparent;border:1px solid var(--line);border-radius:var(--radius-md)}.mobile-menu-close:hover{color:var(--text);background:var(--surface-soft)}.mobile-nav{display:flex;flex-direction:column;gap:2px;padding-bottom:16px}.mobile-nav a{display:flex;align-items:center;min-height:44px;padding:0 12px;color:var(--text);font-size:15px;font-weight:500;border-radius:0;border-left:3px solid transparent}.mobile-nav a:hover,.mobile-nav a.active,.mobile-nav a.router-link-active{color:var(--brand);background:var(--brand-soft);border-left-color:var(--brand)}.mobile-menu-actions{display:flex;flex-direction:column;gap:8px;padding-top:14px;border-top:1px solid var(--line)}.mobile-menu-link{display:flex;align-items:center;justify-content:center;min-height:40px;padding:0 12px;color:var(--text);font-size:14px;font-weight:500;cursor:pointer;background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius-md);text-align:center}.mobile-menu-link:hover{color:var(--brand);border-color:var(--brand)}.mobile-menu-link-danger{color:var(--accent)}.mobile-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;margin-left:6px;font-size:11px;font-weight:600;color:#fff;background:var(--accent);border-radius:9px}.mobile-menu-actions .primary-action{width:100%}.mobile-user-info{display:flex;align-items:center;gap:12px;padding:14px 0 16px;margin-bottom:4px;border-bottom:1px solid var(--line)}.mobile-user-avatar{width:44px;height:44px;flex-shrink:0;object-fit:cover;border-radius:var(--radius-md);border:1px solid var(--line)}.mobile-user-detail{display:flex;flex-direction:column;gap:2px}.mobile-user-name{font-size:15px;font-weight:600;color:var(--text-strong)}.mobile-unread-hint{font-size:12px;color:var(--accent)}@media (max-width: 980px){.mobile-menu-toggle{display:flex}}.page-shell{max-width:var(--layout-max-width);padding:16px var(--layout-gutter) 32px;margin:0 auto}.quick-panel{position:relative;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:center;padding:16px 20px;color:var(--text);background:linear-gradient(135deg,#fff,#eff6ff);border:1px solid var(--line);border-radius:var(--radius-md);margin-bottom:8px;box-shadow:var(--shadow)}.quick-panel:before{display:none}.quick-panel>*{position:relative;z-index:1}.eyebrow{margin:0 0 6px;color:var(--brand);font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.quick-panel .eyebrow{color:var(--brand)}.quick-panel h1,.quick-panel p{margin:0}.quick-panel h1{max-width:600px;margin-bottom:4px;color:var(--text-strong);font-size:22px;font-weight:700;line-height:1.32}.quick-copy{max-width:560px;color:var(--muted);font-size:13px;line-height:1.55}.quick-stats{display:grid;grid-template-columns:repeat(3,auto);gap:8px}.quick-stats span{min-width:98px;padding:9px 12px;color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:none}.quick-stats strong{display:block;margin-bottom:1px;color:var(--text-strong);font-size:19px}.topic-strip{display:flex;gap:0;padding:12px 0 8px;overflow-x:auto;border-bottom:1px solid var(--line);margin-bottom:16px}.topic{display:inline-flex;flex:0 0 auto;align-items:center;justify-content:center;min-height:34px;padding:0 14px;line-height:1;color:var(--muted);font-size:14px;cursor:pointer;background:transparent;border:0;border-bottom:2px solid transparent;border-radius:0;transition:color .15s,border-color .15s;margin-bottom:-1px}.topic:hover{color:var(--brand)}.topic.active{color:var(--brand);font-weight:600;border-bottom-color:var(--brand)}.content-grid{display:grid;grid-template-columns:minmax(0,1fr) var(--layout-sidebar-width);gap:16px;align-items:start}.feed,.sidebar{min-width:0}.section-heading{display:flex;gap:12px;align-items:center;justify-content:space-between;padding-bottom:10px;margin-bottom:12px;border-bottom:1px solid var(--line)}.section-heading.compact{align-items:start}.section-heading h2{margin:0;color:var(--text-strong);font-size:16px;font-weight:700;line-height:1.4}.sort-tabs{display:flex;gap:0;background:transparent;border:0;border-radius:0;box-shadow:none;padding:0}.sort-tabs button{min-height:28px;padding:0 12px;color:var(--muted);font-size:13px;font-weight:500;cursor:pointer;background:transparent;border:0;border-bottom:2px solid transparent;border-radius:0;transition:color .15s,border-color .15s}.sort-tabs button.active{color:var(--brand);font-weight:600;border-bottom-color:var(--brand)}.sort-tabs button:hover:not(.active){color:var(--text);background:transparent}.feed.loading{opacity:.7}.post-item{display:grid;grid-template-columns:minmax(0,1fr) 200px;gap:16px;padding:16px 10px;border-bottom:1px solid var(--line);background:transparent;border-radius:var(--radius-sm);box-shadow:none;margin-bottom:0;cursor:pointer;transition:background .12s}.post-item:first-child{padding-top:8px}.post-item:last-child{border-bottom:0}.post-item:hover{background:var(--surface-soft)}.featured-post{border-color:#f59e0b66;box-shadow:0 0 0 1px #f59e0b22}.post-featured-badge{position:absolute;top:8px;left:8px;z-index:2;padding:2px 7px;font-size:12px;line-height:1.6;font-weight:600;color:#92400e;background:#fef3c7ee;border:1px solid #f59e0b55;border-radius:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none;-webkit-user-select:none;user-select:none}.post-cover{position:relative;order:2;align-self:start;aspect-ratio:16 / 9;overflow:hidden;background:var(--surface-muted);border-radius:var(--radius-md);flex-shrink:0}.post-cover img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.post-item:hover .post-cover img{transform:scale(1.02)}.post-content{display:flex;min-width:0;flex-direction:column}.post-meta,.post-footer{display:flex;flex-wrap:wrap;gap:8px;align-items:center;color:var(--muted);font-size:12px}.post-meta span:first-child{color:var(--brand);font-weight:600;font-size:12px}.post-content h3{margin:6px 0;color:var(--text-strong);font-size:16px;font-weight:700;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.post-content h3 a:hover{color:var(--brand)}.post-content p{margin:0 0 10px;color:var(--muted);font-size:13px;line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.post-footer{margin-top:auto}.author{display:inline-flex;gap:6px;align-items:center;color:var(--text);font-weight:600;font-size:13px}.author img,.author-rank img{width:24px;height:24px;object-fit:cover;border-radius:50%}.feed-message{padding:10px 12px;margin:0 0 12px;color:var(--warning);font-size:13px;background:#fffbeb;border:1px solid rgba(180,83,9,.2);border-radius:var(--radius-md);border-left:3px solid var(--warning)}.pagination-bar{display:grid;gap:10px;padding:14px 0;margin-top:12px;border-top:1px solid var(--line);background:transparent;border-radius:0;box-shadow:none;border-left:0;border-right:0;border-bottom:0}.pagination-bar p{margin:0;color:var(--muted);font-size:13px}.pagination-actions{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.pagination-actions button,.pagination-jump button{min-width:32px;min-height:30px;padding:0 8px;color:var(--text);font-size:13px;cursor:pointer;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);transition:color .12s,border-color .12s,background .12s}.pagination-actions button:hover:not(:disabled),.pagination-jump button:hover:not(:disabled){color:var(--brand);border-color:var(--brand)}.pagination-actions button.active{color:#fff;background:var(--brand);border-color:var(--brand)}.pagination-actions button:disabled,.pagination-jump button:disabled,.pagination-jump input:disabled{cursor:not-allowed;opacity:.4}.pagination-actions button.active:disabled{opacity:1}.pagination-ellipsis{min-width:24px;color:var(--muted);text-align:center;font-size:13px}.pagination-jump{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.pagination-jump label,.pagination-jump span{color:var(--muted);font-size:13px}.pagination-jump input{width:60px;min-height:30px;padding:0 8px;color:var(--text);font-size:13px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);outline:0}.pagination-jump input:focus{border-color:var(--brand)}.sidebar{position:sticky;top:72px}.side-section{padding:16px;margin-bottom:12px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.side-section h2{margin:0 0 12px;color:var(--text-strong);font-size:15px;font-weight:700;line-height:1.4;padding-bottom:8px;border-bottom:1px solid var(--line)}.special-list{display:grid;gap:10px}.special-item{display:grid;grid-template-columns:80px minmax(0,1fr);gap:10px;align-items:center;padding:4px 0;border-radius:0;cursor:pointer}.special-item img{width:80px;height:56px;object-fit:cover;border-radius:var(--radius-sm)}.special-item span{font-size:13px;font-weight:600;line-height:1.4;color:var(--text)}.special-item:hover span{color:var(--brand)}.author-rank{display:grid;gap:0;padding:0;margin:0;list-style:none}.author-rank li{display:grid;grid-template-columns:20px 28px minmax(0,1fr);gap:8px;align-items:center;padding:8px 6px;border-bottom:1px solid var(--line);border-radius:var(--radius-sm);transition:background .12s}.author-rank li:hover{background:var(--surface-soft)}.author-rank li:last-child{border-bottom:0}.rank-no{color:var(--muted);font-weight:700;font-size:13px}.author-rank li:nth-child(1) .rank-no{color:var(--brand)}.author-rank li:nth-child(2) .rank-no{color:#d4740a}.author-rank li:nth-child(3) .rank-no{color:var(--gold)}.author-rank strong,.author-rank span{display:block}.author-rank strong{font-size:13px;font-weight:600;color:var(--text)}.author-rank span{margin-top:1px;color:var(--muted);font-size:12px}.write-box{background:var(--surface);border-color:var(--line)}.write-box p:not(.eyebrow){color:var(--muted);font-size:13px;line-height:1.6}.placeholder-panel{max-width:640px;padding:40px 32px;margin:32px auto;text-align:center;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.placeholder-panel h1{margin:0 0 10px;font-size:22px}.placeholder-panel p:not(.eyebrow){margin:0 auto 18px;color:var(--muted);font-size:14px;line-height:1.7}.auth-layout{display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:24px;max-width:1120px;padding:32px 24px 44px;margin:0 auto}.auth-visual,.auth-panel{min-width:0;border-radius:var(--radius-lg)}.auth-visual{position:relative;display:flex;min-height:480px;padding:36px;color:var(--text-strong);overflow:hidden;flex-direction:column;justify-content:space-between;background:radial-gradient(circle at top left,rgba(37,99,235,.16),transparent 48%),radial-gradient(circle at bottom right,rgba(14,165,233,.14),transparent 44%),linear-gradient(135deg,#fff,#f8fbff 52%,#eef5ff);border:1px solid rgba(37,99,235,.08)}.auth-visual:before{position:absolute;top:0;right:0;bottom:0;left:0;content:"";background:linear-gradient(180deg,#ffffff1f,#ffffff61)}.auth-visual>*{position:relative;z-index:1}.auth-visual .eyebrow{color:var(--brand)}.auth-visual h1{max-width:480px;margin:0 0 10px;font-size:34px;line-height:1.3}.auth-visual p:not(.eyebrow){max-width:480px;margin:0;color:var(--muted);font-size:14px;line-height:1.7}.auth-panel{padding:28px;background:var(--surface);border:1px solid var(--line);box-shadow:none}.auth-panel h2{margin:0 0 8px;font-size:22px;font-weight:700}.auth-panel-copy{margin:0 0 20px;color:var(--muted);font-size:14px;line-height:1.7}.auth-highlights{display:grid;gap:10px;align-self:flex-start}.auth-highlight{display:inline-flex;align-items:center;min-height:34px;width:fit-content;padding:0 14px;color:var(--text);font-size:13px;font-weight:600;background:#ffffffe0;border:1px solid rgba(37,99,235,.12);border-radius:var(--radius-md)}.form-stack{display:grid;gap:14px}.form-stack label,.editor-summary,.editor-title{display:grid;gap:6px}.form-stack span,.editor-summary span{color:var(--text);font-size:13px;font-weight:600}.form-stack input,.editor-summary textarea,.editor-title input,.editor-side input,.editor-side select,.search-large input{width:100%;min-width:0;padding:9px 12px;color:var(--text);font-size:14px;background:var(--surface);border:1px solid var(--line-strong);border-radius:var(--radius-md);outline:0;transition:border-color .15s,box-shadow .15s}.form-stack input:focus,.editor-summary textarea:focus,.editor-title input:focus,.editor-side input:focus,.editor-side select:focus,.search-large input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #2563eb1a}.form-stack small,.error-list{color:var(--accent);font-size:12px}.form-submit{width:100%;border:0;cursor:pointer}.auth-switch{margin:14px 0 0;color:var(--muted);font-size:13px;text-align:center}.auth-switch a{margin-left:6px;color:var(--brand);font-weight:700}.form-message{margin:10px 0 0;color:var(--muted);font-size:13px;line-height:1.5}.form-message.success{color:var(--success);font-weight:600}.form-message.error{color:var(--accent)}.detail-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:16px;align-items:start}.article-main,.article-body,.detail-side,.editor-main,.editor-side,.dashboard-main,.dashboard-nav,.search-panel,.collection-head,.profile-head{min-width:0}.article-main{overflow:hidden;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.empty-state{display:grid;gap:10px;padding:32px}.empty-state h1,.empty-state p{margin:0}.empty-state p:not(.eyebrow){color:var(--muted);font-size:14px;line-height:1.7}.empty-state a{display:inline-flex;width:fit-content;min-height:34px;align-items:center;padding:0 14px;color:#fff;font-size:14px;font-weight:600;background:var(--brand);border-radius:var(--radius-sm)}.article-hero{width:100%;aspect-ratio:16 / 7;object-fit:cover}.article-body{padding:28px 32px}.article-body .markdown-preview{max-width:var(--layout-reading-width)}.article-body h1,.editor-main h1,.dashboard-main h1,.search-panel h1,.collection-head h1,.profile-head h1{margin:0;font-size:26px;font-weight:700;line-height:1.4}.article-summary,.collection-head p,.profile-head p{color:var(--muted);font-size:14px;line-height:1.7}.article-author{display:inline-grid;grid-template-columns:36px minmax(0,1fr);gap:8px;align-items:center;width:fit-content;max-width:min(100%,300px);padding:6px 10px;margin:0;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:var(--shadow)}.article-author img{width:36px;height:36px;object-fit:cover;border-radius:50%}.article-author strong,.article-author span{display:block}.article-author strong{font-size:13px;color:var(--text-strong)}.article-author span{color:var(--muted);font-size:12px;line-height:1.4}.tag-row{display:flex;flex-wrap:wrap;gap:6px;margin:10px 0 18px}.tag-row a,.tag-row button{min-height:26px;padding:0 10px;color:var(--brand);font-size:12px;cursor:pointer;background:var(--brand-soft);border:1px solid rgba(37,99,235,.2);border-radius:var(--radius-md);transition:background .12s,border-color .12s}.tag-row a:hover,.tag-row button:hover{background:var(--brand-hover);border-color:var(--brand)}.tag-row button.active{color:#fff;background:var(--brand);border-color:var(--brand)}.markdown-preview,.rich-editor-content{color:var(--text);font-size:15px;line-height:1.9}.markdown-preview img{display:inline-block}.markdown-preview p:has(>img:only-child){text-align:center}.markdown-preview h1,.markdown-preview h2,.markdown-preview h3,.markdown-preview h4,.markdown-preview h5,.markdown-preview h6{scroll-margin-top:80px;line-height:1.4;color:var(--text-strong)}.markdown-preview h2{border-bottom:1px solid var(--line);padding-bottom:6px}.markdown-preview a,.rich-editor-content a{color:var(--brand);text-decoration:underline;text-underline-offset:2px}.markdown-preview blockquote,.rich-editor-content blockquote{padding:4px 0 4px 14px;margin:16px 0;color:var(--muted);border-left:3px solid var(--brand);background:var(--brand-soft)}.markdown-preview code:not(pre code),.rich-editor-content code:not(pre code){padding:1px 5px;color:var(--brand);font-family:JetBrains Mono,Consolas,monospace;font-size:.88em;background:var(--brand-soft);border-radius:var(--radius-sm)}.markdown-preview table,.rich-editor-content table{width:100%;margin:16px 0;overflow:hidden;border-spacing:0;border:1px solid var(--line);border-radius:var(--radius-sm)}.markdown-preview th,.markdown-preview td,.rich-editor-content th,.rich-editor-content td{min-width:80px;padding:8px 10px;text-align:left;font-size:14px;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}.markdown-preview th,.rich-editor-content th{color:var(--text-strong);background:var(--surface-soft);font-weight:700}.markdown-preview tr:last-child td,.rich-editor-content tr:last-child td{border-bottom:0}.markdown-preview th:last-child,.markdown-preview td:last-child,.rich-editor-content th:last-child,.rich-editor-content td:last-child{border-right:0}.rich-editor-content .tableCellResizer{position:absolute;right:-3px;top:0;width:6px;height:100%;cursor:col-resize;z-index:1;background:transparent;transition:background .12s}.rich-editor-content .tableCellResizer:hover,.rich-editor-content .tableCellResizing{background:#2563eb4d}.rich-editor-content .selectedCell{background:#2563eb0f;border-color:#2563eb38!important}.ProseMirror-gapcursor{display:none;pointer-events:none;position:relative}.ProseMirror-gapcursor:after{content:"";display:block;position:absolute;top:-2px;width:20px;border-top:1px solid black;animation:ProseMirror-cursor-blink 1.1s steps(2,start) infinite}@keyframes ProseMirror-cursor-blink{to{visibility:hidden}}.ProseMirror-focused .ProseMirror-gapcursor{display:block}.md-code-block,.rich-code-block{max-width:100%;margin:16px 0;overflow:hidden;background:#1e1e1e;border:1px solid #333;border-radius:var(--radius-sm)}.md-code-block figcaption,.rich-code-toolbar{display:flex;gap:8px;justify-content:space-between;align-items:center;min-height:34px;padding:0 12px;color:#bbb;font-size:12px;font-weight:700;background:#252526;border-bottom:1px solid #333;border-left:3px solid #555}.md-code-block pre,.rich-code-block pre,.markdown-preview pre{max-width:100%;padding:14px 16px;margin:0;overflow-x:auto;white-space:pre;color:#d4d4d4;font-family:JetBrains Mono,Consolas,monospace;font-size:13px;line-height:1.7;background:transparent}.md-code-block code,.rich-code-block code,.markdown-preview pre code,.rich-editor-content pre code{display:block;min-width:max-content;font-family:inherit;white-space:pre}.rich-code-actions{display:flex;flex-wrap:wrap;gap:4px;justify-content:flex-end}.code-copy-button,.rich-code-toolbar button{min-height:24px;padding:0 8px;color:#ccc;font-size:12px;cursor:pointer;background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-sm);transition:background .12s}.code-copy-button:hover,.rich-code-toolbar button:hover{background:#ffffff29;color:#fff}.rich-code-toolbar button.danger{color:#ff8080}.md-code-block.lang-java figcaption,.rich-code-block.lang-java .rich-code-toolbar{border-left-color:#e05d44}.md-code-block.lang-html figcaption,.rich-code-block.lang-html .rich-code-toolbar{border-left-color:#4c8bf5}.md-code-block.lang-sql figcaption,.rich-code-block.lang-sql .rich-code-toolbar{border-left-color:#d7a72f}.md-code-block.lang-javascript figcaption,.rich-code-block.lang-javascript .rich-code-toolbar,.md-code-block.lang-typescript figcaption,.rich-code-block.lang-typescript .rich-code-toolbar{border-left-color:#6fbf73}.hljs-keyword,.hljs-selector-tag,.hljs-literal{color:#569cd6}.hljs-string,.hljs-title,.hljs-name{color:#9cdca6}.hljs-number,.hljs-built_in,.hljs-type{color:#ce9178}.hljs-comment{color:#6a9955}.detail-side{position:sticky;top:72px}.action-panel{display:grid;gap:8px;padding:16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.action-panel button,.action-panel a,.editor-actions button,.upload-box button,.table-panel button,.search-large button{min-height:34px;padding:0 14px;color:var(--text);font-size:13px;cursor:pointer;text-align:center;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);transition:color .12s,border-color .12s}.action-panel button:not(.primary-action):hover,.action-panel a:not(.primary-action):hover,.editor-actions button:not(.primary-action):hover,.upload-box button:not(.primary-action):hover,.table-panel button:not(.primary-action):hover,.search-large button:not(.primary-action):hover{color:var(--brand);border-color:var(--brand)}.editor-actions .primary-action:hover{filter:brightness(1.06)}.action-panel button.active{color:#fff;background:var(--brand);border-color:var(--brand)}.back-to-top{position:fixed;right:20px;bottom:20px;width:40px;height:40px;color:#fff;font-size:16px;cursor:pointer;background:linear-gradient(135deg,var(--brand),var(--brand-strong));border:none;border-radius:var(--radius-md);box-shadow:0 4px 12px #2563eb4d;opacity:.85;transition:opacity .2s,transform .2s}.back-to-top:hover{opacity:1;transform:translateY(-2px)}.editor-layout{display:grid;grid-template-columns:minmax(0,1fr) var(--layout-editor-sidebar-width);gap:16px;align-items:start}.editor-main{padding:20px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.editor-heading{position:relative;z-index:2}.editor-actions{position:relative;z-index:2;display:flex;gap:8px}.editor-action-status{margin:0 0 12px;padding:8px 12px;font-size:13px;line-height:1.5;border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface-soft)}.editor-action-status.info{color:var(--info);border-color:#2563eb33;background:#2563eb0a}.editor-action-status.success{color:var(--success);border-color:#1e7e4e33;background:#1e7e4e0d}.editor-action-status.warning{color:var(--warning);border-color:#b4530933;background:#b453090d}.editor-action-status.error{color:var(--accent);border-color:#e53e3e33;background:#e53e3e0a}.editor-title input{padding:12px 14px;font-size:22px;font-weight:700}.editor-summary{margin:14px 0}.editor-summary textarea{min-height:80px;resize:vertical}.editor-surface textarea,.rich-markdown-editor{width:100%;color:var(--text);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md)}.rich-markdown-editor{overflow:visible}.editor-sticky-stack{position:sticky;top:68px;z-index:5;background:var(--surface);border-radius:var(--radius-sm) 2px 0 0}.editor-toolbar{display:flex;flex-wrap:wrap;gap:2px;align-items:center;padding:6px 10px;background:var(--surface-soft);border-bottom:1px solid var(--line);border-radius:var(--radius-sm) 2px 0 0}.editor-toolbar-group{display:flex;gap:1px;align-items:center;padding-right:6px;margin-right:4px;border-right:1px solid var(--line)}.editor-toolbar-group:last-child{padding-right:0;margin-right:0;border-right:0}.editor-toolbar button{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;padding:0;color:var(--muted);cursor:pointer;background:transparent;border:none;border-radius:var(--radius-sm);transition:background-color .12s,color .12s}.editor-toolbar button:hover{background:#0000000f;color:var(--text)}.editor-toolbar button.active{background:#2563eb14;color:var(--brand)}.editor-toolbar button:disabled{opacity:.35;cursor:not-allowed;background:transparent}.editor-toolbar button svg{display:block}.table-context-toolbar{display:flex;flex-wrap:wrap;gap:2px;align-items:center;padding:5px 10px;background:var(--surface-soft);border-bottom:1px solid var(--line)}.table-toolbar-label{font-size:12px;font-weight:700;color:var(--text);letter-spacing:.04em;margin-right:2px}.table-toolbar-divider{display:block;width:1px;height:18px;background:var(--line);flex-shrink:0;margin:0 2px}.table-toolbar-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;color:var(--muted);cursor:pointer;background:transparent;border:none;border-radius:var(--radius-sm);transition:background-color .12s,color .12s}.table-toolbar-btn:hover{background:#0000000f;color:var(--text)}.table-toolbar-btn:active{background:#0000001a}.table-toolbar-btn svg{display:block}.table-toolbar-btn--danger:hover{color:#d94a3a;background:#d94a3a14}.table-toolbar-btn--danger:active{background:#d94a3a24}.editor-body{position:relative}.editor-bubble-menu{display:flex;gap:1px;align-items:center;padding:4px 6px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:var(--shadow-md)}.bubble-menu-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;color:var(--muted);cursor:pointer;background:transparent;border:none;border-radius:var(--radius-sm);transition:background-color .1s,color .1s}.bubble-menu-btn:hover{background:#0000000f;color:var(--text)}.bubble-menu-btn.active{background:#2563eb14;color:var(--brand)}.bubble-menu-btn svg{display:block}.bubble-menu-sep{display:block;width:1px;height:18px;margin:0 3px;background:var(--line);flex-shrink:0}.rich-editor-content ul[data-type=task-list]{list-style:none;padding:0;margin:6px 0}.rich-editor-content li[data-type=task-item]{display:flex;align-items:flex-start;gap:8px;margin:3px 0;line-height:1.7}.rich-editor-content li[data-type=task-item] label{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;margin-top:3px;cursor:pointer}.rich-editor-content li[data-type=task-item] input[type=checkbox]{width:15px;height:15px;cursor:pointer;accent-color:var(--brand);border-radius:var(--radius-sm)}.rich-editor-content li[data-type=task-item][data-checked=true]>div>p{text-decoration:line-through;color:var(--muted-light)}.rich-editor-content li[data-type=task-item] div{flex:1;min-width:0}.rich-editor-content ul[data-type=task-list] ul[data-type=task-list]{margin:0}.editor-context-menu{position:fixed;z-index:1000;min-width:180px;max-height:min(70vh,460px);overflow-y:auto;padding:4px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:var(--shadow-md);opacity:0;transform:scale(.96);animation:context-menu-enter .1s ease forwards;transform-origin:top left}.editor-context-menu::-webkit-scrollbar{width:4px}.editor-context-menu::-webkit-scrollbar-thumb{background:#0000001f;border-radius:var(--radius-sm)}.editor-context-menu::-webkit-scrollbar-track{background:transparent}@keyframes context-menu-enter{to{opacity:1;transform:scale(1)}}.context-menu-group{display:flex;flex-direction:column;gap:1px}.context-menu-group-label{padding:5px 10px 3px;color:var(--muted-light);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;-webkit-user-select:none;user-select:none}.context-menu-divider{height:1px;margin:4px 6px;background:var(--line)}.editor-context-item{display:flex;align-items:center;gap:8px;width:100%;min-height:30px;padding:4px 10px;color:var(--text);font-size:13px;font-weight:500;cursor:pointer;text-align:left;background:transparent;border:none;border-radius:var(--radius-sm);transition:background-color .1s}.editor-context-item:hover,.editor-context-item.active{background:var(--brand-soft);color:var(--brand)}.editor-context-item:active{background:var(--brand-hover)}.context-item-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;flex-shrink:0;color:var(--muted)}.editor-context-item:hover .context-item-icon,.editor-context-item.active .context-item-icon{color:var(--brand)}.context-item-label{flex:1;min-width:0}.slash-command-panel{position:absolute;z-index:50;min-width:230px;padding:6px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);opacity:0;transform:scale(.96);animation:context-menu-enter .1s ease forwards;transform-origin:top left}.slash-command-title{margin:0 6px;padding:3px 0;color:var(--muted-light);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.slash-command-empty{margin:0;padding:8px 10px;color:var(--muted);font-size:13px}.slash-command-item{display:flex;align-items:center;gap:8px;width:100%;min-height:36px;padding:4px 10px;color:var(--text);font-size:13px;font-weight:500;cursor:pointer;text-align:left;background:transparent;border:none;border-radius:var(--radius-sm);transition:background-color .1s}.slash-command-item span{font-weight:600;flex-shrink:0}.slash-command-item small{color:var(--muted);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.slash-command-item:hover,.slash-command-item.active{background:var(--brand-soft);color:var(--brand)}.slash-command-item:active{background:var(--brand-hover)}.rich-editor-content{min-height:480px;padding:16px;outline:0}.rich-editor-content:focus{outline:0}.rich-editor-content p{margin:0 0 10px}.rich-editor-content h1,.rich-editor-content h2,.rich-editor-content h3,.rich-editor-content h4,.rich-editor-content h5,.rich-editor-content h6{margin:20px 0 10px;line-height:1.4}.rich-editor-content h1{font-size:26px}.rich-editor-content h2{font-size:22px}.rich-editor-content h3{font-size:18px}.rich-editor-content h4,.rich-editor-content h5,.rich-editor-content h6{font-size:15px}.rich-editor-content .editor-heading-jump-highlight{border-radius:var(--radius-sm);animation:editor-heading-jump-highlight 1.4s ease}@keyframes editor-heading-jump-highlight{0%{background:#2563eb2e;box-shadow:0 0 0 6px #2563eb14}to{background:transparent;box-shadow:0 0 #2563eb00}}.rich-editor-content ul,.rich-editor-content ol{padding-left:22px}.rich-editor-content .tableWrapper{margin:16px 0;overflow-x:auto}.rich-editor-content .selectedCell:after{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;content:"";background:#2563eb14}.rich-editor-content th,.rich-editor-content td{position:relative;vertical-align:top}.editor-side{position:sticky;top:72px}.editor-side .side-section{display:grid;gap:8px}.editor-category-section{padding:12px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.editor-category-head{display:flex;gap:10px;align-items:center;justify-content:space-between}.editor-category-section .eyebrow{margin-bottom:0}.editor-category-value{display:inline-flex;align-items:center;min-height:22px;padding:0 8px;color:var(--brand);font-size:12px;font-weight:600;background:var(--brand-soft);border:1px solid rgba(37,99,235,.2);border-radius:var(--radius-md)}.editor-category-select-wrap{position:relative;background:var(--surface);border:1px solid var(--line-strong);border-radius:var(--radius-md);transition:border-color .15s}.editor-category-select-wrap:after{position:absolute;top:50%;right:12px;width:8px;height:8px;pointer-events:none;content:"";border-right:1.5px solid var(--muted);border-bottom:1.5px solid var(--muted);transform:translateY(-62%) rotate(45deg)}.editor-category-select{min-height:38px;padding-right:36px!important;color:var(--text);font-weight:500;font-size:14px;cursor:pointer;background:transparent!important;border:0!important;box-shadow:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%}.editor-category-select-wrap:focus-within{border-color:var(--brand)}.editor-feedback{display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;margin-top:10px;color:var(--muted);font-size:13px}.editor-dirty{font-weight:600}.editor-dirty.saved{color:var(--success)}.editor-dirty.warning{color:var(--warning)}.editor-status{font-weight:700}.editor-status.success{color:var(--success)}.editor-status.warning,.editor-status.error{color:var(--accent)}.editor-status.info{color:var(--muted)}.publish-result{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:center;padding:16px;margin-bottom:14px;background:#1e7e4e0d;border:1px solid rgba(30,126,78,.22);border-left:3px solid var(--success);border-radius:var(--radius-sm)}.publish-result h2,.publish-result p{margin:0}.publish-result h2{font-size:18px;line-height:1.4}.publish-result p:not(.eyebrow){margin-top:5px;color:var(--muted);font-size:13px;line-height:1.6}.publish-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.publish-meta span{min-height:24px;padding:3px 8px;color:var(--brand);font-size:12px;background:var(--brand-soft);border:1px solid rgba(37,99,235,.18);border-radius:var(--radius-md)}.publish-result-actions{display:flex;gap:8px;align-items:center}.publish-result-actions button:not(.primary-action){min-height:34px;padding:0 12px;color:var(--text);font-size:13px;cursor:pointer;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md)}.publish-result-actions button:not(.primary-action):hover{color:var(--brand);border-color:var(--brand)}.error-list{padding-left:18px;margin:10px 0 0}.upload-box img{width:100%;aspect-ratio:16 / 10;object-fit:cover;border-radius:var(--radius-sm)}.profile-head{display:grid;grid-template-columns:100px minmax(0,1fr);gap:20px;align-items:center;padding:24px;margin-bottom:16px;background:linear-gradient(135deg,#fff,#eff6ff);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.profile-head>img{width:100px;height:100px;object-fit:cover;border-radius:50%;border:2px solid var(--line)}.profile-stats{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}.profile-stats span{min-width:96px;padding:8px 12px;color:var(--muted);font-size:13px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:var(--shadow)}.profile-stats strong{display:block;color:var(--text-strong);font-size:20px;font-weight:700}.dashboard-layout,.admin-layout{display:grid;grid-template-columns:220px minmax(0,1fr);gap:16px;align-items:start}.dashboard-nav{position:sticky;top:72px;display:grid;gap:2px;padding:16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:var(--shadow)}.dashboard-nav a{padding:8px 10px;color:var(--muted);font-size:14px;border-radius:var(--radius-sm);border-left:2px solid transparent;transition:color .12s,background .12s,border-color .12s}.dashboard-nav a:hover{color:var(--brand);background:var(--brand-soft)}.dashboard-nav a.router-link-active{color:var(--brand);background:var(--brand-soft);border-left-color:var(--brand);font-weight:600}.dashboard-main{display:grid;gap:14px}.dashboard-content-panel{min-width:0;padding:20px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:var(--shadow)}.table-panel,.search-panel,.collection-head{padding:20px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:var(--shadow)}.table-panel{overflow-x:auto}.table-panel table{width:100%;min-width:680px;border-spacing:0}.table-panel th,.table-panel td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--line);font-size:13px}.table-panel th{color:var(--muted);font-weight:600;background:var(--surface-soft)}.table-panel td{vertical-align:top}.table-panel td a{color:var(--brand);font-weight:600}.status-pill{display:inline-flex;height:22px;align-items:center;padding:0 8px;font-size:11px;font-weight:600;color:var(--brand);background:var(--brand-soft);border:0;border-left:3px solid var(--brand);border-radius:0 var(--radius-sm) var(--radius-sm) 0;letter-spacing:.01em}.status-pill.warning{color:var(--warning);background:#d9770614;border-left-color:var(--warning)}.status-pill.danger{color:var(--accent);background:#e53e3e14;border-left-color:var(--accent)}.status-pill.success{color:#065f46;background:#d1fae5;border-left-color:#059669}.favorite-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;min-width:0}.favorite-card{overflow:hidden;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);transition:box-shadow .15s}.favorite-card:hover{box-shadow:var(--shadow-md)}.favorite-card img{width:100%;aspect-ratio:16 / 9;object-fit:cover}.favorite-card div{padding:14px}.favorite-card span,.favorite-card p{color:var(--muted);font-size:13px}.favorite-card h2{margin:6px 0;font-size:16px;font-weight:700;line-height:1.4}.favorite-card a{color:var(--brand);font-weight:600;font-size:13px}.search-panel{margin-bottom:16px}.search-large{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;margin-top:14px}.result-note{margin:6px 0 0;color:var(--muted);font-size:13px}.search-large button{color:#fff;background:var(--brand);border-color:var(--brand)}.search-large button:hover{background:var(--brand-strong);border-color:var(--brand-strong);color:#fff}.admin-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.admin-stats article{padding:16px 18px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);border-top:3px solid var(--brand);box-shadow:var(--shadow)}.admin-stats span{color:var(--muted);font-size:13px}.admin-stats strong{display:block;margin-top:6px;font-size:26px;font-weight:700;color:var(--text-strong)}.admin-shell{display:grid;grid-template-columns:var(--layout-admin-sidebar-width) minmax(0,1fr);gap:16px;align-items:start}.admin-sidebar{position:sticky;top:72px;display:grid;gap:12px;max-height:calc(100vh - 88px);overflow-y:auto;overscroll-behavior:contain;padding:16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:var(--shadow);scrollbar-gutter:stable}.admin-sidebar-head h2,.admin-workspace-head h1{margin:0;font-size:16px;font-weight:700}.admin-sidebar-head p:not(.eyebrow),.admin-workspace-head p:not(.eyebrow),.admin-overview-card p,.admin-quick-card span,.admin-log-item p,.admin-empty-panel p:not(.eyebrow),.admin-subtext{margin:0;color:var(--muted);font-size:13px;line-height:1.6}.admin-nav{display:grid;gap:2px}.admin-nav-link{display:grid;grid-template-columns:36px minmax(0,1fr);gap:8px;align-items:center;padding:8px 10px;color:var(--muted);font-size:14px;border:1px solid transparent;border-radius:var(--radius-sm);transition:color .12s,background .12s,border-color .12s;border-left:2px solid transparent}.admin-nav-link:hover{color:var(--brand);background:var(--brand-soft);border-left-color:var(--brand)}.admin-nav-link.router-link-active{color:var(--brand);background:var(--brand-soft);border-left-color:var(--brand);font-weight:600}.admin-nav-icon{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:0 6px;color:var(--brand);font-size:11px;font-weight:700;background:var(--brand-soft);border-radius:var(--radius-sm)}.admin-workspace{display:grid;gap:14px}.admin-workspace-head{display:flex;gap:14px;align-items:end;justify-content:space-between;padding:16px 20px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:var(--shadow)}.admin-refresh-button,.admin-filter-actions button,.admin-pagination-actions button,.admin-pagination-jump button,.admin-drawer-head button,.admin-table button{min-height:32px;padding:0 12px;color:var(--text);font-size:13px;cursor:pointer;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);transition:color .12s,border-color .12s}.btn-export{display:inline-flex;align-items:center;gap:6px;min-height:34px;padding:0 14px;color:var(--success)!important;border-color:var(--success)!important;background:#f0fdf4!important;font-size:13px;font-weight:600;cursor:pointer;border-radius:var(--radius-md);transition:background .12s,box-shadow .12s}.btn-export:hover{background:#dcfce7!important;box-shadow:0 0 0 3px #0596691f}.admin-refresh-button:hover,.admin-filter-actions button:hover,.admin-pagination-actions button:hover:not(:disabled),.admin-pagination-jump button:hover:not(:disabled),.admin-drawer-head button:hover,.admin-table button:hover:not(:disabled){color:var(--brand);border-color:var(--brand)}.admin-page-grid{display:grid;gap:14px}.admin-overview-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.admin-overview-card{display:grid;gap:4px;padding:16px 18px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);border-top:3px solid var(--brand);box-shadow:var(--shadow);transition:box-shadow .15s}.admin-overview-card:hover{box-shadow:var(--shadow-md)}.admin-overview-card span{color:var(--muted);font-size:13px}.admin-overview-card strong{font-size:26px;font-weight:700;color:var(--text-strong)}.admin-quick-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.admin-quick-card{display:grid;gap:6px;padding:16px 18px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);cursor:pointer;text-decoration:none;color:inherit;transition:border-color .15s,box-shadow .15s}.admin-quick-card:hover{border-color:var(--brand);box-shadow:var(--shadow-md);background:var(--brand-soft)}.admin-log-list{display:grid;gap:8px}.admin-log-item{display:flex;gap:10px;align-items:start;justify-content:space-between;padding:11px 14px;background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--line-strong);border-radius:var(--radius-sm);font-size:13px;transition:border-left-color .12s}.admin-log-item:hover{border-left-color:var(--brand);background:var(--surface-soft)}.admin-log-item strong{display:block;margin-bottom:3px;font-weight:600}.admin-empty-panel{display:grid;gap:10px}.admin-empty-actions{display:flex;flex-wrap:wrap;gap:8px}.admin-toolbar{display:grid;gap:12px;margin-bottom:14px}.admin-filter-toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:end}.admin-create-toolbar{padding-bottom:12px;border-bottom:1px solid var(--line)}.admin-filter-toolbar label{display:grid;gap:6px;min-width:150px}.admin-filter-toolbar label span{color:var(--muted);font-size:13px;font-weight:600}.admin-filter-grow{flex:1;min-width:200px}.admin-filter-toolbar input,.admin-filter-toolbar select,.admin-pagination-jump input{min-height:34px;padding:0 10px;color:var(--text);font-size:13px;background:var(--surface);border:1px solid var(--line-strong);border-radius:var(--radius-md);outline:0}.admin-filter-toolbar input:focus,.admin-filter-toolbar select:focus,.admin-pagination-jump input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #2563eb1a}.admin-filter-actions{display:flex;flex-wrap:wrap;gap:8px}.admin-table-shell{min-height:200px}.admin-table-wrap{overflow-x:auto}.admin-table{width:100%;min-width:820px;border-spacing:0}.admin-table th,.admin-table td{padding:10px 12px;text-align:left;vertical-align:top;border-bottom:1px solid var(--line);font-size:13px}.admin-table th{color:var(--muted);font-weight:600;background:var(--surface-soft)}.admin-table td a{color:var(--brand);font-weight:600}.table-actions{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.backend-state-text{margin:0;padding:28px 0;color:var(--muted);font-size:14px;text-align:center}.backend-state-text.subtle{display:inline-flex;width:fit-content;padding:6px 10px;margin-bottom:10px;color:var(--brand-strong);background:var(--brand-soft);border:1px solid var(--brand-hover);border-radius:var(--radius-sm)}.backend-state-text.error-text.subtle{color:var(--accent);background:#d143430f;border-color:#d143431f}.error-text{color:var(--accent)}.success-text{color:var(--success)}.admin-pagination{display:grid;gap:10px;padding-top:14px;margin-top:14px;border-top:1px solid var(--line)}.admin-pagination-summary{margin:0;color:var(--muted);font-size:13px}.admin-pagination-actions{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.admin-pagination-actions button.active{color:#fff;background:var(--brand);border-color:var(--brand)}.admin-pagination-jump{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.admin-pagination-jump label,.admin-pagination-jump span{color:var(--muted);font-size:13px}.admin-drawer-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:18;display:flex;justify-content:flex-end;background:#0000004d}.admin-drawer{width:min(500px,100%);height:100%;padding:20px;overflow-y:auto;background:var(--surface);border-left:1px solid var(--line);box-shadow:-4px 0 16px #0000001a}.admin-drawer-head{display:flex;gap:10px;align-items:start;justify-content:space-between;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--line)}.admin-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:0}.admin-detail-grid div,.admin-drawer-section{padding:12px;margin-top:10px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md)}.admin-detail-grid dt,.admin-drawer-section h3{margin:0 0 6px;font-size:13px;font-weight:700;color:var(--text-strong)}.admin-detail-grid dd,.admin-drawer-section p,.admin-drawer-section pre{margin:0;color:var(--muted);font-size:13px;line-height:1.6}.admin-drawer-section pre{white-space:pre-wrap;word-break:break-word;font-family:JetBrains Mono,Consolas,monospace;font-size:12px}.collection-head{margin-bottom:16px}.notification-wrapper{position:relative}.notification-bell{position:relative;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;cursor:pointer;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);transition:border-color .15s,background .15s}.notification-bell:hover{border-color:var(--brand);background:var(--brand-soft)}.message-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;text-decoration:none;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);transition:border-color .15s,background .15s}.message-btn:hover{border-color:var(--brand);background:var(--brand-soft)}.message-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;color:var(--text)}.message-icon svg{width:100%;height:100%}.bell-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;color:var(--text)}.bell-icon svg{width:100%;height:100%}.unread-badge{position:absolute;top:-5px;right:-5px;min-width:16px;height:16px;padding:0 3px;color:#fff;font-size:10px;font-weight:700;line-height:16px;text-align:center;background:var(--brand);border-radius:var(--radius-sm);box-shadow:0 1px 4px #2563eb66}.notification-dropdown{position:absolute;top:calc(100% + 6px);right:0;z-index:200;width:376px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:0 18px 40px #0f172a1f;overflow:hidden}.notification-header{display:flex;justify-content:space-between;align-items:start;padding:14px 16px 12px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,#fbfdff,#f6f9fe)}.notification-title{color:var(--text-strong);font-weight:700;font-size:15px}.notification-header-copy{display:grid;gap:3px}.notification-subtitle{color:var(--muted);font-size:12px}.mark-all-read{color:var(--brand);font-size:13px;font-weight:600;cursor:pointer;background:transparent;border:0;transition:color .12s}.mark-all-read:hover{color:var(--brand-strong)}.mark-all-read:disabled{color:var(--muted);cursor:not-allowed}.notification-empty{padding:28px 16px;color:var(--muted);font-size:14px;text-align:center}.notification-empty-error{color:var(--accent)}.notification-list{max-height:360px;overflow-y:auto}.notification-item{display:grid;grid-template-columns:40px minmax(0,1fr) auto;gap:12px;align-items:start;padding:14px 16px;cursor:pointer;border-bottom:1px solid var(--line);transition:background .12s,border-color .12s}.notification-item:last-child{border-bottom:0}.notification-item:hover{background:var(--surface-soft)}.notification-item.unread{background:#2563eb0d}.notification-avatar{width:40px;height:40px;object-fit:cover;border-radius:50%}.notification-content{display:grid;gap:4px;min-width:0}.notification-text{color:var(--text);font-size:13px;line-height:1.5;word-break:break-word}.notification-actor{font-weight:700;color:var(--text-strong)}.notification-action{color:var(--text)}.notification-detail{color:var(--muted);font-size:13px;line-height:1.6;display:-webkit-box;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2}.notification-time{color:var(--muted);font-size:12px}.notification-meta{display:inline-flex;gap:10px;align-items:center;padding-top:2px}.unread-dot{width:7px;height:7px;background:var(--brand);border-radius:50%}.notification-arrow{color:var(--muted-light);font-size:18px;line-height:1}.notification-footer{padding:10px 16px;text-align:center;border-top:1px solid var(--line);background:var(--surface-soft)}.view-all-btn{color:var(--brand);font-size:13px;font-weight:600;cursor:pointer;background:transparent;border:0;transition:color .12s}.view-all-btn:hover{color:var(--brand-strong);text-decoration:underline}@media (max-width: 980px){.header-inner{grid-template-columns:auto minmax(0,1fr) auto}.main-nav{display:none}.content-grid{grid-template-columns:1fr}.sidebar{position:static;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.side-section{margin-bottom:0}.write-box{grid-column:1 / -1}.auth-layout,.detail-layout,.dashboard-layout,.admin-layout,.admin-shell{grid-template-columns:1fr}.editor-layout{grid-template-columns:1fr;overflow-x:hidden}.detail-side,.editor-side,.dashboard-nav,.admin-sidebar{position:static;max-height:none;overflow-y:visible}.dashboard-nav,.admin-nav{display:flex;flex-wrap:wrap}.admin-stats,.admin-overview-grid,.admin-quick-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 760px){.section-heading h2{font-size:15px}.header-inner{grid-template-columns:auto minmax(0,1fr) auto;gap:10px;padding:0 14px;min-height:52px}.header-actions{flex-wrap:nowrap;gap:6px;align-items:center}.header-actions .text-link,.header-actions .message-btn,.header-actions .notification-wrapper,.header-actions .user-menu,.search-box,.desktop-write-action{display:none}.mobile-search-toggle{display:flex}.page-shell{padding:12px 14px 24px}.quick-panel{grid-template-columns:1fr;gap:10px;padding:12px 14px;border-radius:var(--radius-md);margin-bottom:8px}.quick-panel h1{font-size:17px;margin-bottom:0}.quick-copy{display:none}.quick-stats{grid-template-columns:repeat(3,1fr);gap:6px}.quick-stats span{min-width:0;padding:8px 10px;box-shadow:none;text-align:center}.quick-stats strong{font-size:16px;margin-bottom:1px}.quick-stats span>:last-child{font-size:11px}.section-heading{align-items:start;flex-direction:column}.post-item{grid-template-columns:1fr;padding:12px 8px;gap:10px}.post-cover{aspect-ratio:16 / 9;order:-1}.sidebar{grid-template-columns:1fr}.auth-layout{padding:14px 14px 24px}.auth-visual{min-height:280px;padding:20px}.auth-panel,.article-body,.editor-main,.dashboard-content-panel,.table-panel,.search-panel,.collection-head,.profile-head{padding:14px}.article-body h1,.editor-main h1,.dashboard-main h1,.search-panel h1,.collection-head h1,.profile-head h1{font-size:20px}.profile-head,.favorite-grid,.admin-stats,.admin-overview-grid,.admin-quick-grid,.admin-detail-grid{grid-template-columns:1fr}.editor-actions{width:100%;flex-direction:column}.publish-result,.publish-result-actions{align-items:stretch;grid-template-columns:1fr;flex-direction:column}.editor-actions .primary-action,.editor-actions button,.publish-result-actions button{width:100%}.editor-sticky-stack{top:116px}.admin-workspace-head,.admin-log-item{flex-direction:column;align-items:stretch}.admin-filter-toolbar,.admin-filter-actions,.admin-pagination-jump{width:100%}.admin-filter-toolbar label,.admin-filter-grow{width:100%;min-width:0}.admin-pagination-jump input,.admin-pagination-jump button,.admin-filter-actions button,.admin-refresh-button,.admin-drawer{width:100%}}@media (max-width: 420px){.section-heading h2{font-size:14px}.quick-panel h1{font-size:18px}.post-content h3{font-size:15px}.sort-tabs{width:100%}.sort-tabs button{flex:1}.pagination-actions button{flex:1 1 calc(33.333% - 4px)}.pagination-jump,.pagination-jump input,.pagination-jump button{width:100%}}#nprogress .bar{background:var(--brand);height:3px;box-shadow:0 0 8px var(--brand)}#nprogress .peg{box-shadow:0 0 10px var(--brand),0 0 5px var(--brand)}
