:root{--bg: #f5f7fa;--surface: #ffffff;--surface2: #eef2ff;--border: #e8ecf1;--text: #1a1a2e;--text2: #64748b;--accent: #4f6ef7;--accent2: #6c8cff;--accent-gradient: linear-gradient(135deg, #4f6ef7 0%, #6c8cff 100%);--success: #16a34a;--warning: #d97706;--danger: #dc2626;--danger-hover: #b91c1c;--danger-soft: #fef2f2;--danger-border: #fecaca;--radius: 12px;--shadow-sm: 0 2px 8px rgba(79, 110, 247, .08);--shadow-md: 0 4px 16px rgba(79, 110, 247, .12)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer;border:none;background:var(--accent);color:#fff;padding:8px 16px;border-radius:8px;font-weight:500;transition:background .15s,box-shadow .15s}button:hover{background:var(--accent2)}button:disabled{opacity:.5;cursor:not-allowed}button.ghost{background:var(--surface);color:var(--text2);border:1px solid var(--border)}button.ghost:hover,button.ghost.active{background:var(--surface2);color:var(--accent);border-color:var(--accent)}button.danger:not(.ghost){background:var(--danger);color:#fff}button.danger:not(.ghost):hover{background:var(--danger-hover);color:#fff}button.ghost.danger,button.ghost.news-fav-remove{background:var(--surface);color:var(--danger);border:1px solid var(--danger-border)}button.ghost.danger:hover,button.ghost.news-fav-remove:hover{background:var(--danger-soft);color:var(--danger-hover);border-color:#f87171}input,select,textarea{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px 12px;width:100%;color:var(--text)}input[type=checkbox],input[type=radio]{width:auto;padding:0}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #4f6ef71f}.app-shell{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:var(--bg)}.app-header{flex-shrink:0;height:56px;display:flex;align-items:center;gap:20px;padding:0 24px;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);z-index:50}.header-logo{display:flex;align-items:center;gap:8px;border:none;background:none;font-size:18px;font-weight:700;color:var(--text);padding:0;flex-shrink:0}.header-logo:hover{color:var(--accent)}.header-logo-icon{font-size:22px}.header-nav{display:flex;align-items:center;gap:4px;flex:1;min-width:0;overflow-x:auto}.header-nav-item{border:none;background:none;padding:8px 14px;border-radius:8px;color:var(--text);font-size:14px;font-weight:500;white-space:nowrap;transition:background .15s,color .15s}.header-nav-item:hover{background:var(--surface2);color:var(--accent)}.header-nav-item.active{background:var(--surface2);color:var(--accent);font-weight:600}.header-right{display:flex;align-items:center;gap:16px;flex-shrink:0}.header-search{display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:0 14px;width:220px}.header-search-icon{font-size:14px;opacity:.6}.header-search input{border:none;background:transparent;padding:8px 0;box-shadow:none}.header-search input:focus{box-shadow:none}.header-auth-actions{display:flex;align-items:center;gap:12px}.header-register-link{background:none;border:none;color:var(--text);padding:8px 4px;font-size:14px;font-weight:400}.header-register-link:hover{color:var(--accent);background:none}.header-login-btn{background:var(--accent);color:#fff;padding:8px 16px;border-radius:8px;font-size:14px;font-weight:500;white-space:nowrap}.header-login-btn:hover{background:var(--accent2)}.header-user{display:flex;align-items:center;gap:10px;font-size:13px}.header-username{color:var(--text2);white-space:nowrap}.header-admin-tag{font-size:11px;padding:2px 8px;border-radius:8px;background:var(--surface2);color:var(--accent)}.header-operator-tag{font-size:11px;padding:2px 8px;border-radius:8px;background:var(--surface2);color:#a78bfa}.header-link-btn{background:none;color:var(--text2);padding:6px 10px;font-size:13px}.header-link-btn:hover{color:var(--accent);background:var(--surface2)}.app-body{flex:1;display:flex;min-height:0;overflow:hidden}.app-body-main{flex:1;overflow-y:auto;min-height:0;background:var(--bg)}.app-body-agent{overflow:hidden;display:flex;flex-direction:column;padding:0}.page-body-wide{width:100%}.sub-sidebar,.category-sidebar{width:200px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);overflow-y:auto;padding:12px 8px}.cat-nav-row{display:flex;align-items:center;gap:4px;margin-bottom:2px}.cat-nav-row .cat-nav-item{flex:1;min-width:0}.cat-nav-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border:none;background:none;color:var(--text);border-radius:8px;cursor:pointer;font-size:12px;text-align:left;transition:background .15s,color .15s;border-left:3px solid transparent}.cat-nav-item:hover{background:var(--bg);color:var(--accent)}.cat-nav-item.active{background:var(--surface2);color:var(--accent);font-weight:600;border-left-color:var(--accent)}.cat-nav-icon{flex-shrink:0;width:20px;text-align:center}.cat-nav-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cat-nav-count{font-size:11px;color:var(--text2);background:var(--bg);padding:1px 6px;border-radius:10px;flex-shrink:0}.page-body{padding:24px 32px 32px;max-width:1200px}.stats-bar{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;min-width:140px;box-shadow:var(--shadow-sm)}.stat-card .value{font-size:28px;font-weight:700;color:var(--accent)}.stat-card .label{font-size:13px;color:var(--text2);margin-top:2px}.toolbar{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.toolbar input{flex:1;min-width:200px;max-width:400px}.bookmark-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}.bookmark-grid-sortable{align-items:start}.bookmark-sort-item{min-width:0}.bookmark-sort-item.is-dragging .bookmark-card{opacity:.45;transform:none;box-shadow:none}.bookmark-sort-item.is-drop-target .bookmark-card{border-color:var(--accent, #2563eb);box-shadow:0 0 0 2px #2563eb33}.bookmark-card{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color .15s,box-shadow .15s,transform .15s}.bookmark-sort-hint{margin:0 0 10px;font-size:12px}.bookmark-sort-controls{position:absolute;top:8px;right:8px;z-index:3;display:flex;gap:4px;opacity:0;transition:opacity .15s}.bookmark-card:hover .bookmark-sort-controls,.bookmark-sort-item.is-dragging .bookmark-sort-controls{opacity:1}.bookmark-sort-handle,.bookmark-sort-btn{width:26px;height:26px;padding:0;border:1px solid var(--border, #e8e8e8);border-radius:6px;background:#fffffff2;color:var(--text2);font-size:12px;line-height:1;cursor:pointer}.bookmark-sort-handle{cursor:grab;letter-spacing:-2px}.bookmark-sort-handle:active{cursor:grabbing}.bookmark-sort-btn:disabled{opacity:.35;cursor:not-allowed}.bookmark-sort-handle:hover,.bookmark-sort-btn:hover:not(:disabled){border-color:var(--accent, #2563eb);color:var(--accent, #2563eb)}.bookmark-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-2px)}.bookmark-card.read{opacity:.72}.card-image{height:140px;background:var(--surface2);display:flex;align-items:center;justify-content:center;overflow:hidden}.card-image img{width:100%;height:100%;object-fit:cover}.card-image .placeholder{font-size:40px;opacity:.35}.card-body{padding:14px 16px}.card-header{display:flex;align-items:flex-start;gap:10px;margin-bottom:8px}.card-header img.favicon{width:20px;height:20px;border-radius:4px;flex-shrink:0;margin-top:2px}.card-title{font-size:15px;font-weight:600;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-title a{color:var(--text);text-decoration:none}.card-title a:hover{color:var(--accent)}.card-summary{font-size:13px;color:var(--text2);line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:10px}.card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.tag{font-size:11px;padding:2px 8px;border-radius:12px;background:var(--surface2);color:var(--accent)}.card-actions{display:flex;gap:6px;flex-wrap:wrap}.card-actions button{font-size:12px;padding:4px 10px}.badge{font-size:11px;padding:2px 8px;border-radius:12px;font-weight:500}.badge.tools{background:var(--surface2);color:var(--accent)}.badge.reading{background:#fff8e1;color:#e65100}.badge.reference{background:#e8f5e9;color:#2e7d32}.badge.favorite{background:#f3e5f5;color:#7b1fa2}.badge.pending{background:#fff3e0;color:var(--warning)}.badge.visibility.public{background:var(--surface2);color:var(--accent)}.badge.visibility.private{background:#f1f5f9;color:var(--text2)}.nav-badge{margin-left:auto;font-size:10px;padding:1px 6px;border-radius:8px;font-weight:500}.nav-badge.public{background:var(--surface2);color:var(--accent)}.nav-badge.private{background:#fff8e1;color:#e65100}.nav-item.login-cta{background:var(--surface2);border:1px solid var(--border);color:var(--accent)}.nav-item.login-cta:hover{border-color:var(--accent)}.empty-state .hint{margin-top:8px;font-size:13px;color:var(--text2)}.login-page{height:100%;overflow-y:auto;display:flex;align-items:center;justify-content:center;background:var(--bg)}.login-box{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:40px;width:100%;max-width:400px;box-shadow:var(--shadow-md)}.login-box h1{font-size:28px;margin-bottom:8px;color:var(--text)}.login-box p{color:var(--text2);margin-bottom:24px}.login-box .field{margin-bottom:16px}.login-box label{display:block;font-size:13px;color:var(--text2);margin-bottom:6px}.login-box .error{color:var(--danger);font-size:13px;margin-top:12px}.auth-mode-tabs{display:flex;gap:8px;margin-bottom:16px}.auth-mode-tabs button{flex:1;background:var(--surface2);color:var(--text2);border:1px solid var(--border);font-weight:500}.auth-mode-tabs button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.auth-panel-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px;border-bottom:1px solid var(--border);min-height:44px}.auth-panel-toolbar-register{padding-top:4px}.auth-panel-title{margin:0;padding:10px 0;font-size:16px;font-weight:600;color:var(--text)}.auth-method-tabs{display:flex;gap:24px;align-items:flex-end}.auth-method-tabs button{padding:10px 0;margin-bottom:-1px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text2);font-size:14px;font-weight:500}.auth-method-tabs button.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.auth-forgot-link{background:none;border:none;color:var(--accent);font-size:12px;padding:0}.auth-forgot-link:hover{text-decoration:underline;background:none}.auth-password-label-row{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}.auth-password-label-row label{margin-bottom:0}.auth-info{color:var(--success, #16a34a);font-size:13px;margin-top:12px}.auth-goto-link{background:none;border:none;color:var(--text2);font-size:13px;padding:8px 0;white-space:nowrap;flex-shrink:0}.auth-goto-link:hover{color:var(--accent);background:none}.auth-page-subtitle{margin:0 0 12px;font-size:13px;color:var(--text2);text-align:left}.auth-primary-btn{width:100%;margin-top:8px;padding:10px 16px;font-size:15px;font-weight:600}.dir-auth-actions{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:8px}.auth-mode-switch{margin:12px 0 0;font-size:13px;color:var(--text2);text-align:center}.auth-mode-switch .linkish{background:none;border:none;color:var(--accent);padding:0 4px;font-size:13px;font-weight:600}.auth-mode-switch .linkish:hover{background:none;text-decoration:underline}.wechat-login-box{text-align:center}.wechat-login-box h1{font-size:24px;margin-bottom:8px}.wechat-login-qr{display:flex;justify-content:center;align-items:center;min-height:300px;margin:12px auto}.auth-wechat-panel{text-align:center}.auth-wechat-panel .auth-page-subtitle{margin-bottom:12px}.wechat-login-qr-inline{min-height:260px;margin:8px auto 12px}.wechat-login-hint{font-size:13px;color:var(--text2);margin:8px 0 0}.wechat-login-warn{color:var(--warning)}.wechat-login-link{display:inline-block;margin-top:10px;font-size:13px;color:var(--accent);text-decoration:none}.wechat-login-link:hover{text-decoration:underline}.wechat-login-section{margin-bottom:8px}.wechat-login-divider{font-size:12px;color:var(--text2);margin:16px 0 12px;text-align:center}.wechat-login-divider{margin:16px 0 12px;font-size:13px;color:var(--text2);text-align:center}.wechat-password-section{margin-top:8px}.phone-login-box{text-align:left}.phone-register-box{padding:28px 24px;max-width:420px}.phone-register-box .auth-page-subtitle{text-align:center;font-size:13px;color:var(--text2);margin:0 0 16px}.phone-register-box .auth-panel-toolbar-register{border-bottom:none;margin-bottom:12px;padding-top:0}.phone-register-box .phone-auth-form .field{margin-bottom:12px}.phone-login-box h1{text-align:center;font-size:24px;margin-bottom:8px}.phone-login-box>section>p{text-align:center;margin-bottom:20px}.phone-auth-form .field{margin-bottom:16px}.phone-auth-code-row{display:flex;gap:8px;align-items:stretch}.phone-auth-code-row input{flex:1;min-width:0}.phone-auth-send-btn{flex-shrink:0;white-space:nowrap;padding:0 14px;font-size:13px;background:var(--surface2);color:var(--text);border:1px solid var(--border)}.phone-auth-send-btn:disabled{opacity:.55;cursor:not-allowed}.phone-auth-send-btn:not(:disabled):hover{border-color:var(--accent);color:var(--accent)}.phone-auth-hint{margin:12px 0 0;font-size:12px;color:var(--text2);text-align:center}.phone-auth-debug{margin:0 0 8px;padding:8px 10px;font-size:12px;color:var(--warning);background:#ffc10714;border-radius:6px;text-align:center}.password-primary-box{text-align:left}.password-primary-box>section>h1,.password-primary-box>section>p:first-of-type{text-align:center}.phone-login-fold{margin-top:4px}.captcha-row{display:flex;gap:8px;align-items:stretch}.captcha-row input{flex:1;min-width:0}.captcha-image-btn{flex-shrink:0;width:120px;height:44px;padding:0;border:1px solid var(--border);background:var(--surface2);overflow:hidden;cursor:pointer}.captcha-image-btn img{display:block;width:100%;height:100%;object-fit:cover}.captcha-placeholder{font-size:12px;color:var(--text2)}.captcha-hint{margin:6px 0 0;font-size:12px;color:var(--warning)}.wechat-admin-login{margin-top:20px;padding-top:16px;border-top:1px solid var(--border);text-align:left}.wechat-admin-toggle{width:100%}.header-username{display:inline-flex;align-items:center;gap:6px}.header-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover}.header-avatar-fallback{line-height:1}.settings-form{max-width:600px}.settings-layout{display:grid;grid-template-columns:minmax(200px,240px) minmax(0,1fr);gap:20px;align-items:start;width:100%;max-width:1120px}.settings-nav{position:sticky;top:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px;box-shadow:var(--shadow-sm)}.settings-nav-search{width:100%;box-sizing:border-box;margin-bottom:10px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:var(--surface2, var(--bg));color:var(--text);font-size:13px}.settings-nav-list{list-style:none;margin:0;padding:0;max-height:calc(100vh - 200px);overflow-y:auto}.settings-nav-item button{width:100%;text-align:left;padding:9px 10px;border:none;background:transparent;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text2);transition:background .15s,color .15s}.settings-nav-item button:hover{background:var(--surface2, rgba(0, 0, 0, .04));color:var(--text)}.settings-nav-item.active button{background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent);font-weight:600}.settings-nav-icon{flex-shrink:0;width:1.25em;text-align:center}.settings-nav-empty{padding:8px 10px}.settings-panel{min-width:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.settings-panel-body.settings-form{max-width:none;padding:20px}.settings-panel-body.settings-form .section{margin-bottom:0;border:none;box-shadow:none;padding:0;background:transparent}.settings-panel-footer{border-top:1px solid var(--border);padding:14px 20px;background:var(--surface2, rgba(0, 0, 0, .02))}@media(max-width:768px){.settings-layout{grid-template-columns:1fr}.settings-nav{position:static}.settings-nav-list{display:flex;flex-wrap:wrap;gap:6px;max-height:none;overflow:visible}.settings-nav-item{flex:0 1 auto}.settings-nav-item button{width:auto;white-space:nowrap;border:1px solid var(--border)}.settings-nav-item.active button{border-color:var(--accent)}}.settings-form .section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:20px;box-shadow:var(--shadow-sm)}.settings-form h3{margin-bottom:16px;font-size:16px;color:var(--text)}.settings-form .field{margin-bottom:14px}.settings-form label{display:block;font-size:13px;color:var(--text2);margin-bottom:6px}.settings-form .hint{font-size:12px;color:var(--text2);margin-top:4px}.empty-state{text-align:center;padding:60px 20px;color:var(--text2);background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius)}.empty-state .icon{font-size:48px;margin-bottom:16px}.dir-main{flex:1;overflow-y:auto;min-height:0;padding:0 32px 48px;background:var(--bg)}.dir-hero-light{text-align:center;padding:40px 20px 32px;margin-bottom:8px}.dir-hero-light h1{font-size:28px;font-weight:700;color:var(--text);margin-bottom:8px}.dir-hero-light p{font-size:14px;color:var(--text2);margin-bottom:24px}.dir-hero-search{display:flex;max-width:560px;margin:0 auto 12px;gap:8px}.dir-hero-search input{flex:1;padding:14px 20px;border-radius:28px;border:1px solid var(--border);box-shadow:var(--shadow-sm);font-size:15px}.dir-hero-search button{padding:14px 24px;border-radius:28px;white-space:nowrap}.dir-manage-link{background:none;color:var(--accent);font-size:13px;padding:4px 8px}.dir-manage-link:hover{text-decoration:underline}.dir-my-favorites{margin-top:8px;padding-top:8px;border-top:none}.home-page{flex:1;overflow-y:auto;min-height:0;padding:24px 32px 40px;max-width:1200px;margin:0 auto;width:100%}.home-intro{text-align:center;padding:48px 20px 40px;margin-bottom:8px}.home-intro-badge{display:inline-block;padding:6px 14px;border-radius:20px;background:var(--surface2);border:1px solid var(--border);font-size:14px;font-weight:600;color:var(--text2);margin-bottom:20px}.home-intro h1{font-size:32px;font-weight:700;margin:0 0 16px;color:var(--text);line-height:1.3}.home-intro-lead{max-width:640px;margin:0 auto 28px;font-size:16px;line-height:1.7;color:var(--text2)}.home-intro-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;align-items:center}.home-intro-actions button:not(.ghost){padding:12px 28px;border-radius:24px;font-size:15px}.home-features{margin-bottom:32px}.home-feature-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.home-feature-card{padding:20px;border-radius:12px;border:1px solid var(--border);background:var(--surface)}.home-feature-icon{font-size:28px;line-height:1;display:block;margin-bottom:10px}.home-feature-card h3{margin:0 0 8px;font-size:16px;font-weight:600;color:var(--text)}.home-feature-card p{margin:0;font-size:13px;line-height:1.6;color:var(--text2)}.home-favorites-empty{margin-bottom:24px}.home-hero{margin-bottom:28px}.home-hero h1{font-size:26px;font-weight:700;margin:0 0 8px;color:var(--text)}.home-hero-sub{margin:0 0 16px;color:var(--text2);font-size:15px}.home-all-bookmarks{margin-top:4px}.home-modules{margin-bottom:32px}.home-module-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.home-module-card{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:16px;border-radius:12px;border:1px solid var(--border);background:var(--surface);text-align:left;transition:border-color .15s,box-shadow .15s}.home-module-card:hover{border-color:var(--accent);box-shadow:0 2px 8px #0000000f}.home-module-icon{font-size:24px;line-height:1}.home-module-label{font-size:15px;font-weight:600;color:var(--text)}.home-module-desc{font-size:12px;color:var(--text2);line-height:1.4}.dir-section-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.dir-favorites-empty{text-align:center;padding:28px 16px 36px;color:var(--text2);font-size:14px}.dir-favorites-empty p{margin-bottom:14px}.dir-favorites-empty button:not(.ghost){padding:10px 22px;border-radius:20px}.dir-badge.starred{background:#fef3c7;color:#b45309}.dir-add-btn,.dir-section-add{flex-shrink:0;width:28px;height:28px;padding:0;border-radius:8px;background:var(--surface2);color:var(--accent);border:1px solid var(--border);font-size:18px;line-height:1;font-weight:600}.dir-add-btn:hover,.dir-section-add:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.dir-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid var(--accent)}.dir-section-head h2{font-size:18px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px}.dir-section-sub{margin:0;font-size:13px;color:var(--text2);font-weight:400}.dir-section-head:has(.dir-section-sub){flex-wrap:wrap;gap:4px 12px}.dir-section-empty{font-size:13px;color:var(--text2);padding:12px 0}.dir-badge.private{background:#f1f5f9;color:var(--text2)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f141e73;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-box{position:relative;max-width:420px;width:100%}.modal-close{position:absolute;top:12px;right:12px;width:32px;height:32px;padding:0;border-radius:8px;background:transparent;color:var(--text2);font-size:22px;line-height:1}.modal-close:hover{background:var(--surface2);color:var(--text)}.add-tool-modal h1{font-size:22px}.tool-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:20px;box-shadow:var(--shadow-sm)}.tool-form .field label{display:block;font-size:13px;color:var(--text2);margin-bottom:6px}.tool-form h3{margin-bottom:16px}.tool-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.tool-form-grid .full{grid-column:1 / -1}.tool-form-grid textarea{resize:vertical;min-height:60px}.checkbox-field label{display:flex;align-items:center;gap:8px;cursor:pointer}.checkbox-field input{width:auto}.tool-form-actions{display:flex;align-items:center;gap:12px;margin-top:16px}.tool-msg{font-size:14px;color:var(--text2)}.tool-count{font-size:13px;color:var(--text2);white-space:nowrap}.tool-loading{color:var(--text2);padding:20px 0}.tool-table-wrap{overflow-x:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.tool-table{width:100%;border-collapse:collapse;font-size:14px}.tool-table th,.tool-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border);vertical-align:top}.tool-table th{background:var(--bg);color:var(--text2);font-weight:600;font-size:12px}.tool-table tr:last-child td{border-bottom:none}.tool-cell-title{display:flex;gap:10px;align-items:flex-start}.tool-cell-title img{width:20px;height:20px;border-radius:4px;flex-shrink:0;margin-top:2px}.tool-cell-title strong{display:block;color:var(--text)}.tool-cell-url{display:block;font-size:11px;color:var(--text2);word-break:break-all;margin-top:2px}.tool-cell-summary{display:block;font-size:12px;color:var(--text2);margin-top:4px;line-height:1.4}.tool-row-actions{display:flex;gap:6px;flex-wrap:wrap}.tool-row-actions button{font-size:12px;padding:4px 10px}@media(max-width:768px){.tool-form-grid{grid-template-columns:1fr}}.dir-section{margin-bottom:36px}.dir-personalized-section{padding:16px 18px 18px;border-radius:14px;border:1px solid color-mix(in srgb,var(--accent) 28%,var(--border));background:color-mix(in srgb,var(--accent) 6%,var(--surface))}.dir-personalized-hint{margin:6px 0 0;font-size:13px;color:var(--text2);line-height:1.5}.dir-section-count{font-size:12px;font-weight:500;color:var(--text2);background:var(--border);padding:2px 8px;border-radius:12px}.dir-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.dir-grid-sortable{align-items:start}.dir-sort-hint{margin:0 0 10px;font-size:12px;color:var(--text2)}.dir-card-sortable .dir-card{padding-right:88px}.dir-card-sortable:hover .bookmark-sort-controls,.bookmark-sort-item.is-dragging .dir-card-sortable .bookmark-sort-controls{opacity:1}.bookmark-sort-item.is-dragging .dir-card-sortable .dir-card{opacity:.45;transform:none;box-shadow:none}.bookmark-sort-item.is-drop-target .dir-card-sortable .dir-card{border-color:var(--accent, #2563eb);box-shadow:0 0 0 2px #2563eb33}.dir-card-wrap{position:relative}.dir-card-wrap .dir-card{padding-right:40px}.dir-card-wrap .gh-card,.dir-card-wrap .news-card{width:100%}.dir-card{display:flex;gap:12px;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;color:inherit;transition:box-shadow .15s,border-color .15s,transform .15s;width:100%;box-sizing:border-box}.dir-card-wrap:hover .dir-card{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-2px)}.dir-fav-btn{position:absolute;top:10px;right:10px;z-index:2;width:28px;height:28px;border:none;border-radius:8px;background:var(--surface2);color:var(--text2);font-size:16px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s,transform .15s}.dir-fav-btn:hover:not(:disabled){background:#fef3c7;color:#b45309;transform:scale(1.08)}.dir-fav-btn.active{background:#fef3c7;color:#d97706}.dir-fav-btn:disabled{opacity:.6;cursor:wait}.dir-add-card{flex-direction:column;align-items:center;justify-content:center;min-height:88px;border-style:dashed;border-color:var(--border);background:var(--surface);cursor:pointer;color:var(--text2);gap:8px}.dir-add-card:hover{border-color:var(--accent);color:var(--accent);background:var(--surface2);transform:translateY(-2px)}.dir-add-card-plus{font-size:32px;font-weight:300;line-height:1;color:var(--accent)}.dir-add-card-text{font-size:13px;font-weight:500}.dir-card-icon{width:44px;height:44px;border-radius:10px;background:var(--surface2);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;font-size:22px}.dir-card-icon img{width:28px;height:28px}.favicon-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center}.favicon-wrap img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;transition:opacity .15s ease}.favicon-fallback{display:flex;align-items:center;justify-content:center;width:28px;height:28px;font-size:12px;font-weight:700;color:#fff;border-radius:6px;letter-spacing:-.02em;text-shadow:0 1px 1px rgba(0,0,0,.18);-webkit-user-select:none;user-select:none}.dir-card-icon .favicon-fallback{width:100%;height:100%;font-size:15px;border-radius:10px}.card-header .favicon-fallback{width:20px;height:20px;font-size:10px;border-radius:4px;flex-shrink:0;margin-top:2px}.dir-card-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.dir-card-desc{font-size:12px;color:var(--text2);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.dir-badge{font-size:10px;padding:1px 6px;border-radius:4px;background:#fff3e0;color:#e65100;font-weight:500}.dir-loading,.dir-empty{padding:80px 40px;text-align:center;color:var(--text2)}.dir-empty-hint{margin:8px auto 0;max-width:420px;font-size:13px;line-height:1.6;color:var(--text2)}.dir-empty-hint strong{color:var(--text);font-weight:600}.news-edition-pending{margin:0 0 16px;padding:10px 14px;font-size:13px;line-height:1.5;color:#92400e;background:#fffbeb;border:1px solid #fde68a;border-radius:10px}.dir-loading-full{flex:1;width:100%;display:flex;align-items:center;justify-content:center}.gh-card-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;font-size:11px;align-items:center}.gh-stars{font-weight:600;color:var(--text)}.gh-lang{padding:1px 6px;border-radius:4px;background:var(--bg2, #f0f0f0);color:var(--text2)}.gh-growth-badge{padding:1px 6px;border-radius:4px;font-weight:500}.gh-growth-badge.up{background:#e8f5e9;color:#2e7d32}.gh-growth-badge.down{background:#ffebee;color:#c62828}.gh-growth-badge.flat{background:#f5f5f5;color:var(--text2)}.gh-growth-label{opacity:.75;font-weight:400}.gh-repo-path{font-size:11px;font-weight:400;color:var(--text2);margin-left:6px}.gh-toolbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.gh-toolbar select{padding:8px 10px;border-radius:8px;border:1px solid var(--border, #ddd)}.gh-sort-select{padding:8px 10px;border-radius:8px;border:1px solid var(--border, #ddd);background:var(--surface);color:var(--text);font-size:13px}.gh-footnote{padding:16px 24px 32px;font-size:12px;color:var(--text2)}.gh-card-icon{padding:0;background:var(--surface2, #f4f4f5);border:1px solid var(--border, #e8e8e8)}.gh-card-icon .gh-repo-icon-wrap,.gh-card-icon .gh-repo-icon-fallback,.gh-card-icon .favicon-wrap,.gh-card-icon .favicon-fallback{width:100%!important;height:100%!important;border-radius:inherit}.gh-card-icon .gh-repo-icon-wrap img,.gh-card-icon .favicon-wrap img{width:100%;height:100%;object-fit:cover;border-radius:inherit}.gh-repo-icon-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;border-radius:10px}.gh-repo-icon-wrap img{position:absolute;top:0;right:0;bottom:0;left:0;transition:opacity .15s ease}.gh-repo-icon-fallback{display:flex;align-items:center;justify-content:center;border-radius:10px;font-size:14px;font-weight:700;color:#fff;letter-spacing:.02em;text-transform:uppercase}.gh-card{position:relative;display:flex;align-items:stretch;padding:0}.gh-card-main{flex:1;display:flex;gap:12px;padding:14px 16px;border:none;background:transparent;text-align:left;cursor:pointer;color:inherit;font:inherit}.gh-card-main:hover{background:var(--bg2, #f8f8f8)}.gh-card-ext{display:flex;align-items:center;justify-content:center;width:36px;color:var(--text2);text-decoration:none;border-left:1px solid var(--border, #eee);font-size:14px}.gh-card-ext:hover{color:var(--accent, #1976d2);background:var(--bg2, #f8f8f8)}.app-body-dir-detail .category-sidebar{display:none}.app-body-dir-detail .dir-main{max-width:900px;margin:0 auto}.gh-detail{padding:0 24px 32px}.gh-detail-back{margin:16px 0 8px;padding:6px 0;border:none;background:none;color:var(--accent, #1976d2);cursor:pointer;font-size:14px}.gh-detail-hero{margin-bottom:24px}.gh-detail-title-row{display:flex;flex-wrap:wrap;align-items:baseline;gap:8px}.gh-detail-title-row h1{margin:0;font-size:28px}.gh-detail-desc{color:var(--text2);line-height:1.6;margin:12px 0}.gh-detail-stats{display:flex;flex-wrap:wrap;gap:12px;font-size:13px;margin-bottom:12px}.gh-detail-topics{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}.gh-topic{font-size:11px;padding:2px 8px;border-radius:12px;background:var(--bg2, #f0f0f0);color:var(--text2)}.gh-detail-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.gh-btn{padding:8px 14px;border-radius:8px;border:1px solid var(--border, #ddd);background:#fff;font-size:13px;cursor:pointer;text-decoration:none;color:var(--text)}.gh-btn.primary{background:var(--accent, #1976d2);color:#fff;border-color:transparent}.gh-btn.accent{background:#e3f2fd;color:#1565c0;border-color:#bbdefb}.gh-btn:disabled{opacity:.6;cursor:not-allowed}.gh-action-msg{font-size:12px;color:#2e7d32}.gh-chart-wrap{background:var(--bg2, #fafafa);border:1px solid var(--border, #eee);border-radius:12px;padding:16px}.gh-chart-head{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:13px;margin-bottom:8px;color:var(--text2)}.gh-chart-delta.up{color:#2e7d32}.gh-chart-delta.down{color:#c62828}.gh-chart{width:100%;height:auto;display:block}.gh-chart-axis{stroke:var(--border, #ddd);stroke-width:1}.gh-chart-line{fill:none;stroke:#1976d2;stroke-width:2}.gh-chart-area{fill:#1976d21f}.gh-chart-dot{fill:#1976d2}.gh-chart-label{font-size:10px;fill:var(--text2, #888)}.gh-chart-empty{font-size:13px;color:var(--text2);margin:0}.gh-admin-head-actions{display:flex;flex-wrap:wrap;gap:8px}.gh-admin{margin:24px;padding:16px;border:1px dashed var(--border, #ddd);border-radius:12px;background:#fffbeb}.gh-admin-form,.gh-admin-discover{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.gh-admin-form input,.gh-admin-discover input{flex:1;min-width:200px}.gh-admin-table{width:100%;border-collapse:collapse;font-size:13px}.gh-admin-table th,.gh-admin-table td{border-bottom:1px solid var(--border, #eee);padding:8px 6px;text-align:left}.gh-admin-discover-list{list-style:none;padding:0;margin:0 0 12px}.gh-admin-discover-list li{display:flex;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--border, #eee);font-size:13px}.gh-admin-discover-list p{margin:4px 0 0;color:var(--text2);font-size:12px}.gh-admin-tracked{font-size:12px;color:var(--text2)}.gh-admin-msg{font-size:12px;color:#1565c0}.gh-admin-loading{font-size:13px;color:var(--text2)}.gh-btn.danger{background:var(--danger);color:#fff}.gh-btn.danger:hover{background:var(--danger-hover);color:#fff}.gh-insight-tool{max-width:720px}.gh-insight-form{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.gh-insight-form input{flex:1;min-width:240px}.gh-insight-result{margin-top:16px;padding:16px;border:1px solid var(--border, #eee);border-radius:12px;background:var(--bg2, #fafafa)}.news-card{padding:0;display:flex}.news-card-link{flex:1;display:flex;align-items:stretch;text-decoration:none;color:inherit;border:none;background:none;padding:0;cursor:pointer;text-align:left;font:inherit}.news-card-ext-link{display:flex;align-items:center;padding:0 12px;color:var(--text2);text-decoration:none;border-left:1px solid var(--border, #eee)}.news-card-ext-link:hover{color:var(--accent, #2563eb);background:var(--bg2, #f8f8f8)}.news-detail{max-width:720px}.news-detail-summary{font-size:15px;line-height:1.65;color:var(--text);margin:16px 0}.news-detail-original{font-size:13px;color:var(--text2);margin:12px 0}.news-detail-label{display:block;font-size:11px;margin-bottom:4px;opacity:.8}.news-detail-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:20px}.gh-admin-subhead{font-size:14px;margin:16px 0 8px;color:var(--text2)}.gh-admin-hint{font-size:12px;color:var(--text2);margin:0 0 8px}.gh-admin-hint code{font-size:11px}.gh-admin-form-stack{flex-direction:column;align-items:stretch}.gh-admin-feed-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis}.gh-admin-error{color:#dc2626}.ai-news-brief-tool{max-width:640px}.ai-news-brief-list{padding-left:20px}.ai-news-brief-list li{margin:12px 0}.ai-news-brief-list p{font-size:13px;color:var(--text2);margin:4px 0}.ai-news-brief-meta{font-size:13px;color:var(--text2)}.news-card .dir-card-body{flex:1;padding:14px 16px}.news-card-link:hover .dir-card-body{background:var(--bg2, #f8f8f8)}.news-card-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;font-size:11px;color:var(--text2)}.news-source{font-weight:600;color:var(--text)}.news-mentions{font-size:11px;padding:2px 6px;border-radius:4px;background:#2563eb1a;color:var(--accent, #2563eb)}.news-edition-hero{display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px 16px;margin-bottom:16px;padding:14px 18px;border-radius:10px;background:linear-gradient(135deg,#2563eb0f,#6366f108);border:1px solid rgba(37,99,235,.1);max-width:820px}.news-edition-hero h1{margin:0;font-size:20px;line-height:1.35}.news-edition-meta{margin:6px 0 0;font-size:12px;color:var(--text2)}.news-edition-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-start}.news-archive-more .cat-nav-label{font-size:12px;color:var(--accent, #2563eb)}.news-archive-all .cat-nav-label{font-size:12px;font-weight:600;color:var(--accent, #2563eb)}.news-archive-page{max-width:960px}.news-archive-page-head{margin-bottom:24px}.news-archive-page-head h1{margin:8px 0 6px;font-size:24px}.news-archive-page-sub{margin:0;color:var(--text2);font-size:14px}.news-archive-back{margin-bottom:4px;padding-left:0}.news-archive-month{margin-bottom:28px}.news-archive-month-title{font-size:16px;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--border, #e8e8e8);color:var(--text2)}.news-archive-month-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.news-archive-card{border:1px solid var(--border, #e8e8e8);border-radius:10px;padding:14px 16px;background:var(--bg, #fff)}.news-archive-card-head{display:flex;justify-content:space-between;align-items:baseline;width:100%;border:none;background:none;padding:0;cursor:pointer;text-align:left}.news-archive-card-head h3{margin:0;font-size:15px}.news-archive-card-count{font-size:12px;color:var(--text2)}.news-archive-card-list{margin:10px 0 8px;padding-left:18px;font-size:13px;line-height:1.5;color:var(--text2)}.news-archive-card-list li{margin:4px 0}.news-detail-toolbar{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}.news-detail-nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.news-detail-nav-pos{font-size:12px;color:var(--text2);padding:0 4px}.news-push-preview{margin:12px 0 16px;border:1px solid var(--border, #e8e8e8);border-radius:10px;background:#f8fafc;overflow:hidden}.news-push-preview-head{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid var(--border, #e8e8e8);background:#fff}.news-push-preview-head h3{margin:0;font-size:14px}.news-kbd-hint{margin:14px 0 0;font-size:12px;color:var(--text2)}.news-kbd-hint kbd{display:inline-block;font-size:11px;padding:1px 5px;border:1px solid var(--border, #ddd);border-radius:4px;background:#f4f4f5;font-family:inherit}.news-push-preview-body{margin:0;padding:14px;font-size:12px;line-height:1.55;white-space:pre-wrap;word-break:break-word;max-height:360px;overflow:auto}.news-admin-settings-link{color:var(--accent, #2563eb);text-decoration:none;font-weight:600}.news-admin-settings-link:hover{text-decoration:underline}.news-admin-failed-sources{margin:8px 0 0;padding-left:18px;font-size:12px;color:var(--text2)}.news-admin-failed-sources li{margin:4px 0}.news-digest-section{background:linear-gradient(135deg,#2563eb0f,#6366f10a);border:1px solid rgba(37,99,235,.12);border-radius:12px;padding:4px 8px 8px}.news-digest-list{margin:0;padding:0 8px 12px 28px;line-height:1.65;font-size:14px;color:var(--text)}.news-digest-list li{margin:10px 0}.news-timeline-section{max-width:820px}.news-timeline-list{display:flex;flex-direction:column;gap:0;border:1px solid var(--border, #e8e8e8);border-radius:10px;overflow:hidden;background:var(--bg, #fff)}.news-timeline-item{display:flex;gap:14px;padding:16px 18px;border-bottom:1px solid var(--border, #eee);align-items:flex-start}.news-timeline-item:last-child{border-bottom:none}.news-timeline-item.focused{outline:2px solid rgba(37,99,235,.45);outline-offset:-2px;background:#2563eb0a}.news-timeline-item.featured{background:linear-gradient(90deg,rgba(255,243,224,.5),transparent)}.news-list-kbd-hint{margin:6px 0 0}.news-newsletter-actions{display:flex;flex-wrap:wrap;gap:6px}.news-newsletter-frame{width:100%;height:420px;border:none;background:#fff}.news-timeline-rank{flex:0 0 28px;font-size:15px;font-weight:700;color:var(--accent, #2563eb);padding-top:2px}.news-timeline-body{flex:1;min-width:0}.news-timeline-title{display:block;width:100%;text-align:left;border:none;background:none;font-size:16px;font-weight:600;line-height:1.45;color:var(--text);cursor:pointer;padding:0;margin:0 0 8px}.news-timeline-title:hover{color:var(--accent, #2563eb)}.news-timeline-badge{display:inline-block;font-size:11px;font-weight:600;color:#c2410c;background:#ffedd5;border-radius:4px;padding:1px 6px;margin-right:8px;vertical-align:middle}.news-timeline-summary{font-size:14px;line-height:1.65;color:var(--text2, #444);margin:0 0 10px}.news-timeline-foot{display:flex;flex-wrap:wrap;gap:10px 16px;align-items:center;font-size:12px;color:var(--text2)}.news-timeline-source{font-weight:600;color:var(--text)}.news-timeline-read{color:var(--accent, #2563eb);text-decoration:none}.news-timeline-read:hover{text-decoration:underline}.news-timeline-fav{position:relative;top:auto;right:auto;flex-shrink:0;margin-top:2px;align-self:flex-start}.news-timeline-fav-link{border:none;background:none;padding:0;font-size:12px;color:var(--text2);cursor:pointer}.news-timeline-fav-link:hover:not(:disabled){color:#b45309}.news-timeline-fav-link.active{color:#d97706;font-weight:600}.news-timeline-fav-link:disabled{opacity:.6;cursor:wait}.news-archive-nav{margin-top:16px;padding-top:12px;border-top:1px solid var(--border, #e8e8e8)}.news-archive-nav-title{font-size:11px;font-weight:600;color:var(--text2);margin:0 0 6px 12px;text-transform:uppercase;letter-spacing:.04em}.news-fav-nav{margin-bottom:8px;padding-bottom:10px;border-bottom:1px solid var(--border, #e8e8e8)}.news-fav-nav-sub{padding-left:28px!important}.news-fav-nav-sub .cat-nav-icon{font-size:13px}.news-fav-manage-btn{margin-top:4px;opacity:.85}.news-fav-manage-btn .cat-nav-label{font-size:12px;color:var(--accent, #2563eb)}.news-feed-cat-title{margin-top:4px}.news-fav-view-hint{margin:4px 0 0;font-size:12px;color:var(--text2)}.news-fav-card-wrap{position:relative}.news-fav-cat-select{position:absolute;left:8px;bottom:8px;z-index:2;font-size:11px;padding:2px 6px;border-radius:6px;border:1px solid var(--border, #e8e8e8);background:var(--surface, #fff);max-width:calc(100% - 48px)}.news-fav-cat-badge{display:inline-block;margin-top:6px;font-size:11px;color:var(--text2);padding:2px 8px;border-radius:10px;background:var(--surface2, #f4f4f5)}.news-fav-manager-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:20px}.news-fav-manager{width:min(440px,100%);background:var(--surface, #fff);border-radius:12px;border:1px solid var(--border, #e8e8e8);padding:20px;box-shadow:0 12px 40px #0000001f}.news-fav-manager-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.news-fav-manager-head h3{margin:0;font-size:16px}.news-fav-manager-hint{margin:0 0 12px;font-size:12px;color:var(--text2)}.news-fav-manager-list{list-style:none;margin:0 0 12px;padding:0;display:flex;flex-direction:column;gap:8px}.news-fav-manager-row{display:flex;align-items:center;gap:8px}.news-fav-manager-icon{width:24px;text-align:center}.news-fav-manager-row input[type=text]{flex:1;min-width:0;padding:6px 10px;border:1px solid var(--border, #e8e8e8);border-radius:8px;font-size:13px}.news-fav-default-radio{font-size:11px;color:var(--text2);white-space:nowrap;display:flex;align-items:center;gap:4px}button.ghost.danger,button.ghost.news-fav-remove{font-size:inherit}.news-fav-manager-add{display:flex;gap:8px;margin-bottom:12px}.news-fav-manager-add input{flex:1;padding:8px 10px;border:1px solid var(--border, #e8e8e8);border-radius:8px}.news-fav-manager-error{margin:0 0 8px;font-size:12px;color:#b91c1c}.news-fav-manager-actions{display:flex;justify-content:flex-end;gap:8px}.news-fav-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;background:#0f172a59;display:flex;align-items:center;justify-content:center;padding:20px}.news-fav-picker{width:min(360px,100%);background:var(--surface, #fff);border-radius:12px;border:1px solid var(--border, #e8e8e8);padding:16px;box-shadow:0 12px 40px #00000026}.news-fav-picker-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.news-fav-picker-head h4{margin:0;font-size:15px}.news-fav-picker-title{margin:0 0 12px;font-size:13px;color:var(--text2);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.news-fav-picker-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.news-fav-picker-item{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border, #e8e8e8);border-radius:10px;background:var(--surface2, #f8fafc);cursor:pointer;text-align:left}.news-fav-picker-item:hover{border-color:var(--accent, #2563eb);background:#eff6ff}.news-fav-picker-item.is-default{border-color:#bfdbfe}.news-fav-picker-icon{font-size:18px}.news-fav-picker-label{flex:1;font-size:14px}.bookmark-cat-official-label{flex:1;font-size:13px}.bookmark-cat-lock{font-size:11px;opacity:.6}.bookmark-cat-manager-section{margin:12px 0 6px;font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.04em}.bookmark-cat-official-list .news-fav-manager-row{opacity:.92}.bookmark-cat-manager-add{flex-wrap:wrap}.bookmark-cat-manager-add select{min-width:120px;flex:1}.bookmark-quick-hint{margin:0 0 12px;font-size:12px;line-height:1.5}.bookmark-quick-hint code{font-size:11px;padding:1px 4px;border-radius:4px;background:var(--surface2, #f4f4f5)}.bookmark-quick-hint kbd{font-size:11px;padding:1px 5px;border-radius:4px;border:1px solid var(--border);background:var(--surface);font-family:inherit}.bookmark-cat-tree-nav{display:flex;flex-direction:column;gap:2px}.bookmark-sidebar-search{margin:0 8px 10px}.bookmark-sidebar-search input{width:100%;font-size:13px;padding:7px 10px;border-radius:8px;border:1px solid var(--border, #e8e8e8);background:var(--surface, #fff)}.bookmark-cat-section-head{display:flex;align-items:center;gap:4px;margin:6px 0 4px;padding:0 8px}.bookmark-cat-section-head .news-archive-nav-title{margin:0;flex:1}.bookmark-cat-section-toggle{width:22px;height:22px;padding:0;border:none;background:transparent;color:var(--text2);cursor:pointer;font-size:11px;line-height:1;border-radius:4px}.bookmark-cat-section-toggle:hover{background:var(--surface2, #f4f4f5)}.bookmark-cat-tree-branch{display:block}.bookmark-cat-tree-row{display:flex;align-items:center;gap:2px;padding-right:6px}.bookmark-cat-tree-row .cat-nav-item{flex:1;min-width:0}.bookmark-cat-toggle,.bookmark-cat-toggle-spacer{flex-shrink:0;width:18px;text-align:center;font-size:10px;color:var(--text2)}.bookmark-cat-toggle{padding:0;border:none;background:transparent;cursor:pointer;line-height:1;border-radius:4px}.bookmark-cat-toggle:hover{background:var(--surface2, #f4f4f5)}.bookmark-cat-add-child,.bookmark-cat-add-root{flex-shrink:0;width:22px;height:22px;padding:0;border:none;border-radius:6px;background:transparent;color:var(--text2);font-size:16px;line-height:1;cursor:pointer;opacity:0;transition:opacity .15s}.bookmark-cat-tree-row:hover .bookmark-cat-add-child,.bookmark-cat-section-head:hover .bookmark-cat-add-root{opacity:1}.bookmark-cat-add-child:hover,.bookmark-cat-add-root:hover{background:var(--surface2, #f4f4f5);color:var(--accent, #2563eb)}.bookmark-list-toolbar{gap:8px}.news-fav-picker-empty{margin:0;font-size:13px;color:var(--text2)}.badge.user-cat{background:#eff6ff;color:#1d4ed8}.news-archive-item .cat-nav-label{font-size:12px}.news-top-picks{max-width:820px;background:#fffbeb;border:1px solid #fde68a;border-radius:10px;padding:4px 16px 12px}.news-top-picks-list{margin:0;padding-left:20px}.news-top-picks-list li{margin:8px 0}.news-top-picks-list button{border:none;background:none;padding:0;font-size:14px;color:var(--text);cursor:pointer;text-align:left}.news-top-picks-list button:hover{color:var(--accent, #2563eb)}.news-date{opacity:.85}.news-legal{font-size:11px;line-height:1.5}.news-admin{background:#f0f9ff}.news-admin-health{margin:10px 0 6px;padding:10px 12px;border-radius:8px;font-size:12px;line-height:1.5;background:#e8f5e9;border:1px solid #a5d6a7}.news-admin-health.warn{background:#fff8e1;border-color:#ffe082}.news-admin-health p{margin:0 0 4px}.news-admin-health-warn{color:#b45309}.news-toolbar select{padding:8px 10px;border-radius:8px;border:1px solid var(--border, #ddd)}.dir-empty code{display:inline-block;margin-top:12px;padding:8px 16px;background:var(--surface2);border-radius:8px;color:var(--accent);font-size:13px}@media(max-width:900px){.app-header{flex-wrap:wrap;align-items:center;height:auto;padding:8px 12px 0;gap:8px}.header-logo{flex-shrink:0}.header-right{margin-left:auto;flex:1;min-width:0;justify-content:flex-end}.header-search{width:auto;flex:1;min-width:0;max-width:200px}.header-nav{display:flex;width:100%;flex:none;order:10;gap:2px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:6px 0 8px;border-top:1px solid var(--border);margin-top:2px}.header-nav::-webkit-scrollbar{display:none}.header-nav-item{flex-shrink:0;padding:7px 12px;font-size:13px}.category-sidebar,.sub-sidebar{width:160px}.dir-main{padding:0 16px 32px}.dir-hero-light{padding:28px 12px 24px}.dir-hero-light h1{font-size:22px}.home-page{padding:16px 16px 32px}.home-intro{padding:32px 12px 28px}.home-intro h1{font-size:24px}.home-intro-lead{font-size:15px}.page-body{padding:20px 16px 24px}}@media(max-width:768px){.app-body-dir,.app-body{flex-direction:column}.category-sidebar,.sub-sidebar{width:100%;max-height:120px;display:flex;flex-wrap:wrap;gap:4px;border-right:none;border-bottom:1px solid var(--border)}.cat-nav-row,.cat-nav-item{width:auto}.page-body{padding:16px}.utility-columns{grid-template-columns:1fr}}.utility-body{overflow:auto;height:100%}.utility-hub{display:flex;flex:1;min-height:0;height:100%}.utility-card{text-align:left;width:100%;background:var(--surface);border:1px solid var(--border)}.utility-card-icon{font-size:28px;display:flex;align-items:center;justify-content:center}.utility-page{padding:24px 32px 32px;max-width:1200px;margin:0 auto}.utility-page-head{margin-bottom:20px}.utility-back{margin-bottom:12px}.utility-page-title{display:flex;gap:12px;align-items:flex-start}.utility-page-icon{font-size:32px}.utility-page-title h2{font-size:22px;margin-bottom:4px}.utility-page-title p{color:var(--text2);font-size:14px}.utility-columns{display:grid;grid-template-columns:1fr 1fr;gap:16px}.utility-columns-3{grid-template-columns:repeat(3,1fr)}.utility-form-stack{display:flex;flex-direction:column;gap:16px}.utility-panel{display:flex;flex-direction:column;gap:8px}.utility-panel-head{display:flex;justify-content:space-between;align-items:center;gap:8px}.utility-panel-head label{font-weight:600;font-size:14px}.utility-panel-actions{display:flex;gap:8px;align-items:center}.utility-textarea{width:100%;padding:12px;border:1px solid var(--border);border-radius:8px;background:var(--surface);resize:vertical;font-family:ui-monospace,Consolas,monospace;font-size:13px;line-height:1.5}.utility-textarea.has-error{border-color:var(--danger)}.utility-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #4f6ef726}.utility-error{color:var(--danger);font-size:13px}.utility-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:16px}.utility-inline-actions{display:flex;gap:8px;flex-wrap:wrap}.utility-inline-label,.utility-check-label{display:inline-flex;align-items:center;gap:4px;font-size:14px;color:var(--text2)}.utility-hint{font-size:12px;color:var(--text2)}.utility-hint-block{font-size:13px;color:var(--text2);margin-top:8px}.utility-gradient-preview{height:80px;border-radius:8px;border:1px solid var(--border)}.utility-ok{color:#15803d}.utility-diff-panel{grid-column:1 / -1}.utility-diff{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:12px;font-family:ui-monospace,Consolas,monospace;font-size:13px;max-height:320px;overflow:auto}.diff-line.diff-add{color:var(--success);background:#16a34a14}.diff-line.diff-remove{color:var(--danger);background:#dc26260f}.diff-line.diff-same{color:var(--text2)}.utility-markdown-preview{min-height:280px;padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:var(--surface);font-size:14px;line-height:1.6;overflow:auto}.utility-markdown-preview h1,.utility-markdown-preview h2,.utility-markdown-preview h3{margin:.6em 0 .4em}.utility-markdown-preview pre{background:var(--bg);padding:10px;border-radius:6px;overflow:auto}.utility-markdown-preview code{font-family:ui-monospace,Consolas,monospace;font-size:13px}.utility-ref-table-wrap{margin-top:4px}.utility-ref-search{width:100%;max-width:360px;padding:8px 12px;border:1px solid var(--border);border-radius:8px;margin-bottom:12px;font-size:14px}.utility-ref-table{width:100%;border-collapse:collapse;font-size:14px}.utility-ref-table th,.utility-ref-table td{border:1px solid var(--border);padding:8px 12px;text-align:left}.utility-ref-table th{background:var(--bg);font-weight:600}.utility-ref-table tbody tr:hover{background:#3b82f60a}.utility-color-swatch{width:100%;height:48px;border-radius:8px;border:1px solid var(--border);margin-top:12px}.utility-image-preview{max-width:100%;max-height:320px;border-radius:8px;border:1px solid var(--border);object-fit:contain;background:var(--bg)}.utility-qr-panel{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px}.utility-qr-canvas{max-width:100%;border:1px solid var(--border);border-radius:8px}.utility-file-label{display:flex;flex-direction:column;gap:6px;font-size:14px;font-weight:500}.utility-file-label input[type=file]{font-size:13px}.utility-file-list{margin:0;padding-left:20px;font-size:13px;color:var(--text2)}.agent-page{display:flex;height:100%;min-height:0;overflow:hidden}.agent-sidebar{width:260px;flex-shrink:0;border-right:1px solid var(--border);background:var(--surface);display:flex;flex-direction:column;min-height:0}.agent-sidebar-head{padding:12px;border-bottom:1px solid var(--border)}.agent-sidebar-head button{width:100%}.agent-session-search{margin:8px 12px;font-size:13px;padding:8px 10px}.agent-session-list{flex:1;overflow-y:auto;padding:4px 8px 12px}.agent-session-item{display:block;width:100%;text-align:left;background:none;color:var(--text);border:none;border-radius:8px;padding:10px 28px 10px 10px;margin-bottom:4px;position:relative;font-weight:400}.agent-session-item:hover{background:var(--surface2)}.agent-session-item.active{background:var(--surface2);color:var(--accent)}.agent-session-item .title{display:block;font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.agent-session-item .meta{display:block;font-size:11px;color:var(--text2);margin-top:2px}.agent-session-item .del{position:absolute;right:8px;top:50%;transform:translateY(-50%);color:var(--text2);font-size:16px;padding:2px 6px;border-radius:4px}.agent-session-item .del:hover{color:var(--danger);background:#fef2f2}.agent-main{flex:1;display:flex;flex-direction:column;min-height:0;min-width:0}.agent-tabs{display:flex;align-items:center;gap:8px;padding:10px 16px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.agent-tab-opts{margin-left:auto;display:flex;gap:12px;font-size:13px;color:var(--text2)}.agent-tab-opts label{display:flex;align-items:center;gap:4px;cursor:pointer}.agent-messages{flex:1;overflow-y:auto;padding:20px 24px;min-height:0}.agent-empty{text-align:center;padding:60px 20px;color:var(--text2)}.agent-empty .icon{font-size:48px;margin-bottom:12px}.agent-empty .hint{font-size:13px;margin-top:8px}.agent-msg{max-width:720px;margin-bottom:16px}.agent-msg-user{margin-left:auto}.agent-msg-user .agent-msg-body{background:var(--accent-gradient);color:#fff;border-radius:12px 12px 4px}.agent-msg-assistant .agent-msg-body{background:var(--surface);border:1px solid var(--border);border-radius:12px 12px 12px 4px}.agent-msg-role{font-size:11px;color:var(--text2);margin-bottom:4px}.agent-msg-user .agent-msg-role{text-align:right}.agent-msg-body{padding:12px 14px;font-size:14px;line-height:1.6;white-space:pre-wrap}.agent-tool-calls{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.agent-tool-chip{font-size:11px;padding:2px 8px;border-radius:999px;background:var(--surface2);color:var(--accent);border:1px solid var(--border)}.agent-tool-chip.fail{color:var(--danger);border-color:#fecaca;background:#fef2f2}.agent-input-bar{display:flex;gap:10px;padding:12px 16px;border-top:1px solid var(--border);background:var(--surface);flex-shrink:0}.agent-input-bar textarea{flex:1;resize:none;min-height:44px}.agent-input-bar button{align-self:flex-end;flex-shrink:0}.agent-panel{flex:1;overflow-y:auto;min-height:0}.agent-behavior-insights{margin-bottom:18px;padding:12px 14px;border-radius:var(--radius);border:1px solid var(--border);background:#6366f10d}.agent-briefings-panel{margin:0 0 12px;padding:12px 14px;border:1px solid color-mix(in srgb,var(--accent) 24%,var(--border));border-radius:var(--radius);background:color-mix(in srgb,var(--accent) 5%,var(--surface))}.agent-briefings-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}.agent-briefings-head h3{margin:0;font-size:15px}.agent-briefings-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.agent-briefings-badge{font-size:12px;color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent);padding:2px 8px;border-radius:10px}.agent-briefings-empty{font-size:13px;color:var(--text2)}.agent-briefings-empty button{margin-top:8px}.agent-briefings-list{display:flex;flex-direction:column;gap:8px}.agent-briefing-card{border:1px solid var(--border);border-radius:10px;background:var(--surface);overflow:hidden}.agent-briefing-card.unread{border-color:color-mix(in srgb,var(--accent) 35%,var(--border))}.agent-briefing-toggle{width:100%;display:grid;grid-template-columns:auto 1fr auto auto;gap:8px;align-items:center;padding:10px 12px;border:none;background:transparent;text-align:left;cursor:pointer;color:inherit}.agent-briefing-kind{font-size:11px;padding:2px 8px;border-radius:999px;background:var(--border);color:var(--text2);white-space:nowrap}.agent-briefing-kind.weekly{background:#3b82f626;color:#3b82f6}.agent-briefing-kind.alert{background:#f59e0b26;color:#d97706}.agent-briefing-kind.daily{background:#10b98126;color:#059669}.agent-briefing-title{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.agent-briefing-dot{width:8px;height:8px;border-radius:50%;background:var(--accent)}.agent-briefing-time{font-size:11px;color:var(--text2)}.agent-briefing-body{padding:0 12px 12px;font-size:13px;border-top:1px solid var(--border)}.agent-briefing-body .agent-markdown{margin:10px 0}.content-feedback-bar{margin-top:16px;padding:12px 14px;border-radius:10px;border:1px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.content-feedback-bar.compact{margin-top:0;padding:0;border:none;background:transparent;justify-content:flex-start}.content-feedback-label{font-size:13px;color:var(--text2)}.content-feedback-actions{display:flex;gap:8px}.content-feedback-btn{font-size:13px;padding:6px 12px;border-radius:8px;border:1px solid var(--border);background:transparent;cursor:pointer;color:inherit}.content-feedback-btn.active.helpful{border-color:#059669;background:#10b9811f}.content-feedback-btn.active.unhelpful{border-color:#d97706;background:#f59e0b1f}.agent-growth-metrics{margin-bottom:18px;padding:12px 14px;border-radius:var(--radius);border:1px solid var(--border);background:#10b9810d}.agent-growth-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;margin-top:10px}.agent-growth-card{display:flex;flex-direction:column;gap:4px;padding:10px 12px;border-radius:8px;background:var(--surface);border:1px solid var(--border)}.agent-growth-card strong{font-size:20px}.agent-growth-label{font-size:12px;color:var(--text2)}.agent-fab{position:fixed;right:22px;bottom:22px;z-index:1200;display:inline-flex;align-items:center;gap:8px;padding:12px 16px;border-radius:999px;border:none;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;box-shadow:0 8px 24px #6366f159;cursor:pointer;font-weight:600}.agent-fab-icon{font-size:18px}.agent-drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;z-index:1300;display:flex;justify-content:flex-end}.agent-drawer{width:min(420px,100vw);height:100%;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;box-shadow:-8px 0 32px #0000001f}.agent-drawer-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border)}.agent-drawer-actions{display:flex;gap:8px}.agent-drawer-messages{flex:1;overflow-y:auto;padding:12px 16px}.agent-drawer-empty{margin-top:24px}.agent-drawer-input{display:grid;grid-template-columns:1fr auto;gap:8px;padding:12px 16px 16px;border-top:1px solid var(--border)}.agent-drawer-input textarea{resize:vertical;min-height:44px}.agent-next-actions{margin:0 16px 20px;padding:12px 14px;border-radius:var(--radius);border:1px dashed color-mix(in srgb,var(--accent) 30%,var(--border));background:color-mix(in srgb,var(--accent) 4%,var(--surface))}.agent-next-actions-head{display:flex;align-items:baseline;gap:10px;margin-bottom:10px;flex-wrap:wrap}.agent-next-actions-list{display:flex;flex-wrap:wrap;gap:8px}.agent-next-action-btn{font-size:13px;padding:8px 12px;border-radius:999px;border:1px solid var(--border);background:var(--surface);cursor:pointer;color:inherit}.agent-next-action-btn:hover{border-color:var(--accent);color:var(--accent)}.agent-page-context-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px;padding:8px 12px;border-radius:8px;background:color-mix(in srgb,var(--accent) 8%,var(--surface));border:1px solid color-mix(in srgb,var(--accent) 20%,var(--border));font-size:13px}.agent-behavior-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.agent-behavior-tags{margin:6px 0 0;font-size:13px;color:var(--text2);line-height:1.5}.agent-skill-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.agent-skill-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px}.agent-skill-card .head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.agent-skill-card .badge{font-size:11px;padding:2px 8px;border-radius:999px;background:var(--surface2);color:var(--accent)}.agent-skill-card p{font-size:13px;color:var(--text2);margin-bottom:8px}.agent-skill-card .meta{font-size:11px;color:var(--text2)}.agent-skill-actions{display:flex;gap:8px;margin-top:10px}.agent-skill-actions button{font-size:12px;padding:4px 10px}.agent-quick-prompts{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:16px}.agent-quick-prompts button{font-size:13px}.agent-tool-chip.active{animation:agent-pulse 1.2s ease-in-out infinite}@keyframes agent-pulse{0%,to{opacity:1}50%{opacity:.5}}.agent-cursor{display:inline-block;margin-left:2px;animation:agent-blink 1s step-end infinite}@keyframes agent-blink{50%{opacity:0}}.agent-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:200;padding:24px}.agent-modal{background:var(--surface);border-radius:var(--radius);padding:24px;max-width:640px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-md)}.agent-modal h3{margin-bottom:8px;display:flex;align-items:center;gap:8px}.agent-stats-hint{font-size:12px;color:var(--text2);margin-left:8px}.agent-postprocess-hint{padding:6px 16px;font-size:13px;color:var(--accent);background:var(--surface2);border-bottom:1px solid var(--border)}.agent-confirm-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:8px 16px;font-size:13px;color:var(--text);background:#fff3cd;border-bottom:1px solid #f0d78c}.agent-confirm-bar span{flex:1;min-width:200px}.agent-md code{background:var(--surface2);padding:1px 5px;border-radius:4px;font-size:.9em}.agent-md pre{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:10px;overflow-x:auto;margin:8px 0;font-size:12px}.agent-md a{color:var(--accent)}.agent-skill-diff{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:12px 0}.agent-skill-diff .agent-skill-content{max-height:180px}.agent-skill-content{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:12px;font-size:12px;line-height:1.5;max-height:240px;overflow-y:auto;white-space:pre-wrap;margin:12px 0}.agent-runs-table-wrap{overflow-x:auto}.agent-runs-table{width:100%;border-collapse:collapse;font-size:13px}.agent-runs-table th,.agent-runs-table td{padding:8px 10px;border-bottom:1px solid var(--border);text-align:left}.agent-runs-table th{color:var(--text2);font-weight:500}.agent-runs-table tr.fail td{color:var(--danger)}.agent-runs-table .linkish{padding:0;font-size:inherit;color:var(--accent);text-decoration:underline}.agent-run-msg{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text2)}.agent-sidebar-actions{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:0 12px 10px}.agent-sidebar-actions .hint{font-size:11px}.learn-hub:not(:has(.category-sidebar)) .dir-main{max-width:960px;margin:0 auto}.learn-intro{color:var(--text2);font-size:14px;line-height:1.7;margin-bottom:20px}.learn-path-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.learn-path-card{text-align:left;padding:20px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .15s}.learn-path-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-2px)}.learn-path-card-head{display:flex;gap:12px;align-items:flex-start;margin-bottom:10px}.learn-path-icon{font-size:32px;line-height:1}.learn-path-card h3{font-size:18px;margin:0 0 4px;color:var(--text)}.learn-path-card-head p{margin:0;font-size:13px;color:var(--text2)}.learn-path-audience{font-size:13px;color:var(--text2);margin:0 0 12px;line-height:1.5}.learn-path-meta{display:flex;justify-content:space-between;font-size:12px;color:var(--text2);margin-bottom:10px}.learn-progress-bar{height:8px;border-radius:4px;background:var(--surface2);overflow:hidden}.learn-progress-fill{height:100%;background:linear-gradient(90deg,#f59e0b,#f97316);border-radius:4px;transition:width .25s ease}.learn-path-progress-text{font-size:13px;color:var(--text2);margin-top:8px}.learn-agent-coach{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin:0 0 20px;padding:16px 18px;border-radius:var(--radius);border:1px solid var(--border);background:linear-gradient(135deg,#6366f114,#10b9810f)}.learn-agent-coach.lesson{margin-top:16px;padding:0;border:none;background:none;justify-content:flex-start}.learn-agent-coach strong{display:block;margin-bottom:4px}.learn-agent-coach p{margin:0;font-size:13px;color:var(--text2);max-width:520px}.learn-agent-coach-btn{flex-shrink:0;padding:10px 16px;border-radius:var(--radius);border:none;background:var(--accent);color:#fff;font-size:14px;font-weight:600;cursor:pointer}.learn-agent-coach-btn:hover{filter:brightness(1.05)}.learn-agent-coach-btn.inline{margin-top:12px}.learn-coach-toast{position:fixed;right:20px;bottom:20px;z-index:1200;max-width:380px;padding:14px 16px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);box-shadow:0 8px 28px #0000002e;display:flex;flex-direction:column;gap:10px}.learn-coach-toast-body strong{display:block;margin-bottom:4px}.learn-coach-toast-body p{margin:0;font-size:13px;color:var(--text2);line-height:1.5}.learn-coach-toast-meta{display:block;margin-top:6px;font-size:12px;color:var(--text3)}.learn-coach-toast-actions{display:flex;gap:8px}.learn-coach-toast-actions button{padding:6px 12px;font-size:13px}.learn-cert-export-hint{font-size:13px;color:var(--accent);margin:8px 0 0}.learn-principles{margin:0;padding-left:20px;color:var(--text2);line-height:1.9;font-size:14px}.learn-module-summary{color:var(--text2);font-size:14px;margin:-8px 0 16px}.learn-lesson-list{display:flex;flex-direction:column;gap:8px}.learn-lesson-row{display:flex;align-items:center;gap:12px;width:100%;text-align:left;padding:14px 16px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);cursor:pointer;transition:border-color .15s,box-shadow .15s}.learn-lesson-row:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}.learn-lesson-status{width:20px;text-align:center;color:var(--accent);font-weight:700}.learn-lesson-row-body{flex:1;display:flex;flex-direction:column;gap:4px}.learn-lesson-row-body strong{font-size:15px;color:var(--text)}.learn-lesson-row-body span{font-size:12px;color:var(--text2)}.learn-lesson-arrow{color:var(--text2)}.learn-sidebar-module{margin-top:8px}.learn-sidebar-module-title{font-size:11px;font-weight:600;color:var(--text2);padding:8px 14px 4px;text-transform:uppercase;letter-spacing:.04em}.learn-lesson-nav{padding-left:20px!important;font-size:13px}.learn-lesson-nav .cat-nav-label{white-space:normal;line-height:1.35}.learn-back-btn{margin:16px 0 8px;padding:6px 0;border:none;background:none;color:var(--accent);cursor:pointer;font-size:14px}.learn-lesson-duration{font-size:13px;color:var(--text2);white-space:nowrap}.learn-objectives,.learn-section-block,.learn-tasks,.learn-links{margin-bottom:24px}.learn-objectives h3,.learn-section-block h3,.learn-tasks h3,.learn-links h3{font-size:16px;margin-bottom:10px;color:var(--text)}.learn-objectives ul{margin:0;padding-left:20px;color:var(--text2);line-height:1.8}.learn-section-block p{margin:0 0 8px;color:var(--text2);line-height:1.75;font-size:14px}.learn-task-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;margin-bottom:8px;border-radius:8px;background:var(--surface2);cursor:pointer;font-size:14px;line-height:1.5}.learn-task-item input{margin-top:3px;flex-shrink:0;width:auto}.learn-task-item span{flex:1;min-width:0;color:var(--text)}.learn-lesson-complete input{width:auto;flex-shrink:0}.learn-task-hint{font-size:13px;color:#b45309;margin:4px 0 0}.learn-lesson-complete{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;margin-bottom:20px;cursor:pointer}.learn-link-row{display:flex;flex-wrap:wrap;gap:10px}.learn-link-btn{padding:8px 14px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--accent);font-size:13px;cursor:pointer}.learn-link-btn:hover{border-color:var(--accent);background:var(--surface2)}.learn-lesson-pager{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-top:8px;padding-top:16px;border-top:1px solid var(--border)}.learn-lesson-main .learn-lesson-pager button{max-width:48%}.learn-continue-banner{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:16px 0 8px;padding:16px 20px;border-radius:var(--radius);border:1px solid #fcd34d;background:linear-gradient(135deg,#fffbeb,#fef3c7)}.learn-continue-banner strong{display:block;font-size:13px;color:#b45309;margin-bottom:4px}.learn-continue-banner p{margin:0;font-size:16px;font-weight:600;color:var(--text)}.learn-continue-meta{font-size:12px;color:var(--text2)}.learn-sync-hint{font-size:12px;color:var(--text2);font-weight:400}.learn-path-card{position:relative}.learn-path-card.completed{border-color:#fcd34d}.learn-complete-badge{position:absolute;top:12px;right:12px;font-size:11px;font-weight:700;padding:3px 8px;border-radius:6px;background:#fef3c7;color:#b45309}.learn-complete-badge.inline{position:static;margin-left:8px;vertical-align:middle}.learn-resource-group{margin-bottom:28px}.learn-resource-group:last-child{margin-bottom:0}.learn-resource-group-head{margin-bottom:12px}.learn-resource-group-head h3{font-size:17px;margin:0 0 4px;color:var(--text)}.learn-resource-group-head p{margin:0;font-size:13px;color:var(--text2)}.learn-resource-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}.learn-resource-card{display:flex;flex-direction:column;gap:6px;padding:14px 16px;border-radius:10px;border:1px solid var(--border);background:var(--surface);text-decoration:none;color:inherit;transition:border-color .15s,box-shadow .15s}.learn-resource-card:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}.learn-resource-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.learn-resource-card-head strong{font-size:15px;line-height:1.35;color:var(--text)}.learn-resource-lang{flex-shrink:0;font-size:11px;padding:2px 6px;border-radius:4px;background:var(--surface2);color:var(--text2)}.learn-resource-provider{font-size:12px;color:var(--accent)}.learn-resource-desc{margin:0;font-size:13px;line-height:1.5;color:var(--text2);flex:1}.learn-resource-meta{display:flex;flex-wrap:wrap;gap:8px 12px;font-size:11px;color:var(--text2);margin-top:4px}.learn-prompt-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.learn-prompt-card{padding:14px 16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);display:flex;flex-direction:column;gap:10px}.learn-prompt-head{display:flex;flex-direction:column;gap:4px}.learn-prompt-scene{font-size:12px;color:var(--text2)}.learn-prompt-body{margin:0;padding:10px 12px;border-radius:8px;background:var(--surface2);font-size:12px;line-height:1.55;white-space:pre-wrap;color:var(--text2);max-height:160px;overflow:auto}.learn-hub-stats{display:flex;flex-wrap:wrap;align-items:center;gap:12px 20px;margin-bottom:20px;padding:14px 16px;border-radius:10px;background:var(--surface2)}.learn-stat-item{display:flex;flex-direction:column;gap:2px;min-width:72px}.learn-stat-item strong{font-size:20px;line-height:1.2;color:var(--text)}.learn-stat-item span{font-size:12px;color:var(--text2)}.learn-export-btn{margin-left:auto;font-size:13px}.learn-path-card-main{display:block;width:100%;padding:0;border:none;background:transparent;text-align:left;color:inherit;cursor:pointer}.learn-path-card-main:hover{opacity:.92}.learn-cert-link{display:block;width:100%;margin-top:10px;padding:8px 0 0;border:none;border-top:1px solid var(--border);background:transparent;font-size:13px;color:var(--accent);cursor:pointer;text-align:center}.learn-cert-link.path{width:auto;margin-top:12px;padding:0;border:none;text-align:left}.learn-notes{margin-top:20px}.learn-notes h3{margin:0 0 6px;font-size:15px}.learn-notes-hint{margin:0 0 8px;font-size:12px;color:var(--text2)}.learn-notes-input{width:100%;min-height:100px;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);font-family:inherit;font-size:14px;line-height:1.5;resize:vertical}.learn-notes-input:focus{outline:none;border-color:var(--accent)}.learn-cert-modal{max-width:420px;text-align:center}.learn-cert-inner{padding:8px 4px 4px}.learn-cert-seal{font-size:48px;line-height:1;margin-bottom:8px}.learn-cert-modal h2{margin:0 0 4px;font-size:22px}.learn-cert-sub{margin:0 0 16px;font-size:13px;color:var(--text2)}.learn-cert-body{padding:16px;border-radius:10px;background:var(--surface2);margin-bottom:12px}.learn-cert-name{margin:0 0 8px;font-size:18px;font-weight:600}.learn-cert-date{margin:8px 0 0;font-size:13px;color:var(--text2)}.learn-cert-tip{margin:0 0 16px;font-size:12px;color:var(--text2)}.learn-cert-actions{display:flex;gap:10px;justify-content:center}.learn-curriculum-version-tag{font-size:12px;color:var(--text2);background:var(--bg2, #f3f4f6);padding:2px 8px;border-radius:999px;margin-left:8px}.learn-curriculum-admin{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:12px;padding:16px 20px}.learn-curriculum-admin-msg{margin:0 0 12px;color:#166534;font-size:13px}.learn-curriculum-block{margin-top:16px}.learn-curriculum-block h3{margin:0 0 10px;font-size:15px}.learn-curriculum-proposals{display:flex;flex-direction:column;gap:12px}.learn-curriculum-proposal-card{background:#fff;border:1px solid #d1fae5;border-radius:10px;padding:12px 14px}.learn-curriculum-proposal-head{display:flex;flex-wrap:wrap;gap:10px;align-items:center;font-size:13px;color:var(--text2)}.learn-curriculum-proposal-time{margin-left:auto;font-size:12px}.learn-curriculum-rationale{margin:8px 0;font-size:14px}.learn-curriculum-ops{margin:0 0 10px;padding-left:18px;font-size:13px;color:var(--text2)}.learn-curriculum-proposal-actions{display:flex;gap:8px}.learn-curriculum-status{display:inline-block;font-size:11px;padding:1px 6px;border-radius:4px;text-transform:uppercase}.learn-curriculum-status.active{background:#dcfce7;color:#166534}.learn-curriculum-status.archived{background:#f3f4f6;color:#6b7280}.learn-curriculum-status.pending{background:#fef3c7;color:#b45309}.learn-curriculum-status.approved{background:#dbeafe;color:#1d4ed8}.learn-curriculum-status.rejected{background:#fee2e2;color:#b91c1c}.learn-curriculum-note{max-width:280px;font-size:13px;color:var(--text2)}.learn-curriculum-history{list-style:none;margin:0;padding:0;font-size:13px}.learn-curriculum-history li{display:flex;flex-wrap:wrap;gap:8px;padding:6px 0;border-bottom:1px solid #e5e7eb}.learn-curriculum-feedback-list{list-style:none;margin:0;padding:0;font-size:13px}.learn-curriculum-feedback-list li{display:flex;flex-wrap:wrap;justify-content:space-between;gap:8px;padding:8px 0;border-bottom:1px solid #e5e7eb}.agent-curriculum-alert{background:#fef3c7;border:1px solid #fcd34d;border-radius:10px;padding:12px 14px;margin-bottom:16px}.agent-curriculum-alert p{margin:6px 0 8px;font-size:13px;color:var(--text2)}.agent-curriculum-alert-link{font-size:13px;font-weight:600}.agent-evolution-dashboard{margin-bottom:20px;padding:14px 16px;background:#fffbeb;border:1px solid #fde68a;border-radius:12px}.agent-evolution-head{display:flex;align-items:center;gap:10px;margin-bottom:6px}.agent-evolution-badge{font-size:12px;padding:2px 8px;border-radius:999px;background:#f59e0b;color:#fff}.agent-evolution-badge.muted{background:#e5e7eb;color:#6b7280}.agent-evolution-links{display:flex;flex-wrap:wrap;gap:12px;margin:8px 0}.agent-evolution-chip{display:inline-block;margin:0 6px 4px 0;padding:2px 8px;font-size:12px;border-radius:6px;background:#ecfdf5;color:#047857}.agent-evolution-chip.warn{background:#fef2f2;color:#b91c1c}.news-admin-health-maint{margin:6px 0 0;font-size:12px;color:#166534}.learn-curriculum-operator{background:#eff6ff;border:1px solid #bfdbfe;border-radius:12px;padding:16px 20px}.learn-curriculum-operator-form{display:flex;flex-direction:column;gap:12px;margin-top:12px}.learn-curriculum-operator-form label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:600}.learn-curriculum-operator-form textarea{font-weight:400;font-family:inherit;resize:vertical}.dir-catalog-admin{margin-top:24px;padding:16px 20px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:12px}.dir-catalog-admin-head{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:12px}.dir-catalog-admin-head h3{margin:0}.evolution-center{max-width:960px}.evolution-center-head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px}.evolution-center-head h2{margin:0 0 6px}.evolution-center-actions{display:flex;flex-wrap:wrap;gap:8px}.evolution-center-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin-bottom:16px}.evolution-stat-card{padding:12px 14px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;text-align:center}.evolution-stat-card strong{display:block;font-size:22px;margin-bottom:4px}.evolution-stat-card.accent{background:#ecfdf5;border-color:#a7f3d0}.evolution-center-section{margin-top:24px}.evolution-section-head{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px;margin-bottom:12px}.evolution-section-head h3{margin:0}.evolution-signal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.evolution-signal-card{padding:12px 14px;background:#fffbeb;border:1px solid #fde68a;border-radius:10px}.evolution-signal-card h4{margin:0 0 8px;font-size:14px}.evolution-signal-card ul{margin:0;padding-left:18px;font-size:13px}.evolution-proposal-list{display:flex;flex-direction:column;gap:12px}.learn-curriculum-proposal-card.low-risk{border-color:#86efac;background:#f0fdf4}.evolution-auto-tag,.evolution-low-risk-tag{font-size:11px;padding:1px 6px;border-radius:4px}.evolution-auto-tag{background:#dbeafe;color:#1d4ed8}.evolution-low-risk-tag{background:#dcfce7;color:#166534}.evolution-center-workflow{margin-top:28px;padding:14px 16px;background:#f1f5f9;border-radius:10px}.evolution-center-workflow ul{margin:8px 0 0;padding-left:20px}.agent-evolution-banner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px;margin-bottom:16px;padding:10px 14px;background:#fffbeb;border:1px solid #fde68a;border-radius:10px}.evolution-diff{margin-top:10px;padding:10px 12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px}.evolution-diff-item{margin-top:10px;padding-top:10px;border-top:1px dashed #e2e8f0}.evolution-diff-item:first-of-type{margin-top:6px;padding-top:0;border-top:none}.evolution-diff-summary{font-weight:600;font-size:13px;margin-bottom:6px}.evolution-diff-before,.evolution-diff-after{font-size:12px;margin-top:4px}.evolution-diff-before span,.evolution-diff-after span{display:inline-block;min-width:48px;font-weight:600;color:#64748b}.evolution-diff-before pre,.evolution-diff-after pre{margin:4px 0 0;padding:8px;white-space:pre-wrap;word-break:break-word;border-radius:6px;font-family:inherit;font-size:12px;line-height:1.45}.evolution-diff-before pre{background:#fef2f2;color:#991b1b}.evolution-diff-after pre{background:#ecfdf5;color:#166534}.evolution-stale-banner{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.25rem;padding:.85rem 1rem;border-radius:10px;border:1px solid rgba(245,158,11,.35);background:#f59e0b14}.evolution-history-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.evolution-history-card{padding:.85rem 1rem;border-radius:10px;border:1px solid var(--border);background:var(--surface-elevated, rgba(255, 255, 255, .02))}.evolution-history-card h4{margin:0 0 .5rem;font-size:.95rem}.evolution-history-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.45rem}.evolution-history-list li{font-size:.85rem;line-height:1.45}.evolution-history-kind{font-weight:600}.evolution-history-status.status-approved{color:#22c55e}.evolution-history-status.status-rejected{color:#ef4444}.evolution-history-status.status-expired{color:#f59e0b}.evolution-history-rationale{display:block;color:var(--text-muted, #94a3b8);font-size:.8rem}.evolution-history-time{display:block;color:var(--text-muted, #94a3b8);font-size:.75rem}.evolution-history-action{margin-left:.35rem;padding:.1rem .45rem;font-size:.75rem;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--accent);cursor:pointer}.evolution-history-action:hover:not(:disabled){background:var(--surface2)}.evolution-history-actions{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.2rem}.evolution-history-link{font-size:.75rem;color:var(--text-muted, #94a3b8)}.evolution-history-version{color:var(--text-muted, #94a3b8);font-size:.8rem}.evolution-versions-panel{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.evolution-versions-panel h4{margin:0 0 .65rem;font-size:.95rem}.evolution-versions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.evolution-versions-col strong{display:block;margin-bottom:.15rem}.evolution-versions-list{list-style:none;margin:.5rem 0 0;padding:0;display:flex;flex-direction:column;gap:.35rem}.evolution-versions-list li{display:flex;align-items:center;justify-content:space-between;gap:.5rem;font-size:.85rem}.evolution-version-active{color:#22c55e;font-weight:600}.notification-bell{position:relative}.notification-bell-btn{position:relative;background:transparent;border:none;font-size:1.1rem;cursor:pointer;padding:4px 6px;line-height:1}.notification-bell-badge{position:absolute;top:-2px;right:-2px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;line-height:16px;text-align:center}.notification-panel{position:absolute;right:0;top:calc(100% + 8px);width:min(320px,90vw);max-height:360px;overflow:auto;background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px #0000001f;z-index:200}.notification-panel-head{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--border)}.notification-panel-empty{padding:16px 12px;margin:0}.notification-list{list-style:none;margin:0;padding:0}.notification-item{display:block;width:100%;text-align:left;padding:10px 12px;border:none;border-bottom:1px solid var(--border);background:transparent;cursor:pointer}.notification-item.unread{background:#3b82f60f}.notification-item-title{display:block;font-size:13px;font-weight:600}.notification-item-body{display:block;font-size:12px;color:var(--text2);margin-top:4px}.notification-item-time{display:block;font-size:11px;color:var(--text3, #94a3b8);margin-top:4px}.site-feedback-mine,.site-feedback-admin-list{list-style:none;margin:12px 0 0;padding:0;display:flex;flex-direction:column;gap:10px}.site-feedback-mine li,.site-feedback-admin-item{padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface2, rgba(0, 0, 0, .02))}.site-feedback-status.status-open{color:#f59e0b}.site-feedback-status.status-read{color:#3b82f6}.site-feedback-status.status-resolved{color:#22c55e}.site-feedback-reply{margin-top:6px;padding:6px 8px;border-radius:6px;background:#22c55e14}.site-feedback-admin-meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:6px;font-size:13px}.site-feedback-admin-actions{display:flex;gap:8px;margin-top:8px}.site-announcement-list{list-style:none;margin:12px 0 0;padding:0;display:flex;flex-direction:column;gap:10px}.site-announcement-item{padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface2, rgba(0, 0, 0, .02))}.notification-item.kind-announcement .notification-item-title:before{content:"📢 "}.notes-page{display:flex;flex:1;min-height:0;height:100%;gap:0}.notes-sidebar{width:300px;flex-shrink:0;border-right:1px solid var(--border);display:flex;flex-direction:column;background:var(--surface);min-height:0}.notes-sidebar-head{display:flex;align-items:center;justify-content:space-between;padding:16px 14px 10px}.notes-sidebar-head h2{margin:0;font-size:16px}.note-folder-nav{padding:0 10px 8px;border-bottom:1px solid var(--border);flex-shrink:0;max-height:34vh;overflow-y:auto}.note-folder-nav-head{display:flex;align-items:center;justify-content:space-between;padding:8px 4px 6px;font-size:12px;color:var(--text-muted)}.note-folder-nav-head .ghost{font-size:12px;padding:2px 6px}.note-folder-nav-actions{display:flex;align-items:center;gap:4px}.note-folder-icon-input{width:36px;min-width:36px;text-align:center;padding:4px 2px}.note-folder-manager-count{font-size:12px;color:var(--text-muted);min-width:20px;text-align:center}.note-folder-item{display:flex;align-items:center;gap:6px;width:100%;border:none;background:transparent;color:var(--text);padding:6px 8px;border-radius:6px;cursor:pointer;font-size:13px;text-align:left}.note-folder-item.root{margin-bottom:2px}.note-folder-item:hover{background:var(--surface-2, rgba(0, 0, 0, .04))}.note-folder-item.active{background:var(--accent-soft, rgba(59, 130, 246, .12));color:var(--accent, #3b82f6);font-weight:600}.note-folder-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.note-folder-count{font-size:11px;color:var(--text-muted)}.note-folder-row{display:flex;align-items:center;gap:2px}.note-folder-toggle,.note-folder-toggle-spacer{width:16px;flex-shrink:0;text-align:center;font-size:10px;color:var(--text-muted)}.note-folder-toggle{border:none;background:transparent;cursor:pointer;padding:0}.note-folder-add-child{border:none;background:transparent;color:var(--text-muted);cursor:pointer;padding:0 4px;font-size:14px;line-height:1}.note-folder-add-child:hover{color:var(--accent, #3b82f6)}.notes-folder-badge{font-size:11px;color:var(--text-muted);background:var(--surface-2, rgba(0, 0, 0, .05));padding:1px 6px;border-radius:4px}.notes-search{margin:0 12px 10px;width:calc(100% - 24px)}.notes-list{flex:1;overflow-y:auto;padding:0 8px 12px}.notes-list-item{display:block;width:100%;text-align:left;border:1px solid transparent;border-radius:10px;padding:10px 12px;margin-bottom:6px;background:var(--bg);cursor:pointer;color:inherit}.notes-list-item:hover{border-color:var(--border)}.notes-list-item.active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--bg))}.notes-list-title{display:flex;align-items:center;gap:6px;font-weight:600;font-size:14px;line-height:1.35}.notes-pin{flex-shrink:0}.notes-list-meta{display:flex;align-items:center;gap:8px;margin-top:4px;font-size:11px;color:var(--muted)}.notes-type-badge{padding:1px 6px;border-radius:4px;background:var(--surface);border:1px solid var(--border)}.notes-type-badge.type-idea{border-color:#f59e0b55;color:#b45309}.notes-type-badge.type-learn{border-color:#3b82f655;color:#1d4ed8}.notes-list-snippet{margin-top:6px;font-size:12px;color:var(--muted);line-height:1.4}.notes-editor{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0;background:var(--bg)}.notes-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px 24px;text-align:center;color:var(--muted)}.notes-empty h3{margin:0;color:var(--text)}.notes-toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;padding:14px 16px 8px;border-bottom:1px solid var(--border)}.notes-title-input{flex:1;min-width:200px;font-size:18px;font-weight:600;border:none;background:transparent;padding:6px 0}.notes-title-input:focus{outline:none}.notes-toolbar-actions{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.notes-toolbar-actions select{width:auto;min-width:88px}.notes-tags-input{margin:8px 16px 0;width:calc(100% - 32px);font-size:13px}.notes-editor-body{flex:1;min-height:0;padding:12px 16px 8px;display:flex;flex-direction:column}.notes-textarea{flex:1;min-height:280px;resize:none;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:14px;line-height:1.55}.notes-preview{flex:1;overflow-y:auto;padding:8px 4px;border:1px solid var(--border);border-radius:10px;background:var(--surface)}.notes-status-bar{display:flex;gap:16px;padding:8px 16px 12px;font-size:12px;color:var(--muted);border-top:1px solid var(--border)}@media(max-width:900px){.notes-page{flex-direction:column}.notes-sidebar{width:100%;max-height:38vh;border-right:none;border-bottom:1px solid var(--border)}}.library-page{display:flex;flex:1;min-height:0;height:100%;width:100%}.library-sidebar{width:300px;flex-shrink:0;border-right:1px solid var(--border);display:flex;flex-direction:column;background:var(--surface);min-height:0;overflow:hidden}.library-sidebar-search{padding:0 12px 10px;flex-shrink:0}.library-sidebar-search input{width:100%;font-size:13px;padding:7px 10px;border-radius:8px;border:1px solid var(--border);background:var(--bg)}.library-sidebar-body{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column}.library-sidebar-body .note-folder-nav{max-height:none;flex-shrink:0;border-bottom:none}.library-sidebar-body .notes-list{flex:1;min-height:0;overflow-y:auto;padding:0 8px 8px}.library-main{flex:1;min-width:0;min-height:0;overflow-y:auto;display:flex;flex-direction:column;background:var(--bg)}.library-cat-nav-actions{display:flex;align-items:center;gap:4px;margin-left:auto}.library-cat-nav-actions .ghost{font-size:12px;padding:2px 6px}.library-cat-section-head{width:100%}.library-tab-bar{display:flex;gap:4px;padding:12px 16px 0;border-bottom:1px solid var(--border);flex-shrink:0}.library-tab-bar-sidebar{padding:12px 12px 0}.library-tab-bar-sidebar .library-tab{flex:1;text-align:center}.library-tab{padding:8px 16px;border:none;background:transparent;color:var(--text-muted);font-size:14px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.library-tab:hover{color:var(--text)}.library-tab.active{color:var(--text);border-bottom-color:var(--accent);font-weight:600}@media(max-width:900px){.library-page{flex-direction:column}.library-sidebar{width:100%;max-height:42vh;border-right:none;border-bottom:1px solid var(--border)}}
