:root{--bg-root: #f8fafc;--bg-surface: #ffffff;--bg-subtle: #f1f5f9;--bg-hover: #e8eef5;--bg-glass: rgba(255, 255, 255, .8);--bg-card: #ffffff;--bg-elevated: #fafbfd;--accent: #6366f1;--accent-light: #818cf8;--accent-soft: rgba(99, 102, 241, .06);--accent-glow: rgba(99, 102, 241, .12);--accent-2: #06b6d4;--accent-2-soft: rgba(6, 182, 212, .06);--accent-3: #10b981;--accent-3-soft: rgba(16, 185, 129, .06);--gradient-brand: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #a855f7 100%);--gradient-hero-text: linear-gradient(135deg, #6366f1 0%, #06b6d4 50%, #8b5cf6 100%);--gradient-card-accent: linear-gradient(135deg, #6366f1, #8b5cf6);--gradient-aurora: linear-gradient(135deg, #6366f1 0%, #06b6d4 33%, #8b5cf6 66%, #f59e0b 100%);--gradient-success: linear-gradient(135deg, #10b981, #06b6d4);--gradient-warning: linear-gradient(135deg, #f59e0b, #f97316);--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #94a3b8;--text-on-brand: #ffffff;--text-muted: #cbd5e1;--border: #e2e8f0;--border-light: #f1f5f9;--border-focus: rgba(99, 102, 241, .3);--border-glow: rgba(99, 102, 241, .2);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .03);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .04), 0 1px 2px rgba(0, 0, 0, .02);--shadow-md: 0 4px 14px rgba(0, 0, 0, .04), 0 1px 3px rgba(0, 0, 0, .03);--shadow-lg: 0 12px 36px rgba(0, 0, 0, .05), 0 2px 8px rgba(0, 0, 0, .03);--shadow-xl: 0 24px 60px rgba(0, 0, 0, .06), 0 4px 16px rgba(0, 0, 0, .03);--shadow-glow: 0 0 0 4px rgba(99, 102, 241, .08);--shadow-glow-lg: 0 0 0 8px rgba(99, 102, 241, .05), 0 12px 40px rgba(99, 102, 241, .06);--shadow-card-hover: 0 8px 28px rgba(0, 0, 0, .06), 0 2px 6px rgba(99, 102, 241, .06);--r-xs: 6px;--r-sm: 10px;--r-md: 14px;--r-lg: 18px;--r-xl: 24px;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--danger: #ef4444;--danger-soft: rgba(239, 68, 68, .06);--warning: #f59e0b;--warning-soft: rgba(245, 158, 11, .06);--success: #10b981;--success-soft: rgba(16, 185, 129, .06)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{max-width:100%;overflow-x:hidden}body{margin:0;min-height:100vh;background:var(--bg-root);color:var(--text-primary);font-family:Noto Sans SC,Inter,PingFang SC,Microsoft YaHei,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}button,input,select,textarea{font:inherit}button{cursor:pointer}.bg-noise{position:fixed;inset:0;pointer-events:none;z-index:5;opacity:.015;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px 256px}.bg-aura{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}.bg-aura:before{content:"";position:absolute;top:-20%;right:-5%;width:65vw;height:65vw;background:radial-gradient(ellipse 70% 70% at 60% 35%,rgba(108,60,225,.12) 0%,rgba(139,92,246,.06) 20%,rgba(168,85,247,.02) 45%,transparent 65%);animation:floatBig 16s ease-in-out infinite}.bg-aura:after{content:"";position:absolute;bottom:-15%;left:-8%;width:55vw;height:55vw;background:radial-gradient(ellipse 65% 65% at 35% 65%,rgba(6,182,212,.1) 0%,rgba(16,185,129,.05) 25%,rgba(108,60,225,.03) 55%,transparent 70%);animation:floatBig 20s ease-in-out infinite reverse}.bg-aura-wrapper{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}.bg-aura-wrapper:before{content:"";position:absolute;top:10%;left:-12%;width:45vw;height:45vw;background:radial-gradient(ellipse 60% 60% at 40% 40%,rgba(245,158,11,.07) 0%,rgba(249,115,22,.03) 25%,rgba(236,72,153,.02) 50%,transparent 70%);animation:floatSlow 24s ease-in-out infinite}.bg-aura-wrapper:after{content:"";position:absolute;bottom:5%;right:-5%;width:40vw;height:40vw;background:radial-gradient(ellipse 55% 55% at 60% 60%,rgba(168,85,247,.08) 0%,rgba(236,72,153,.04) 30%,rgba(108,60,225,.02) 55%,transparent 70%);animation:floatSlow 22s ease-in-out infinite reverse}.bg-midblob{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}.bg-midblob:before{content:"";position:absolute;top:30%;left:25%;width:50vw;height:50vw;background:radial-gradient(ellipse 50% 50% at 50% 50%,rgba(99,102,241,.05) 0%,rgba(139,92,246,.03) 30%,rgba(6,182,212,.02) 50%,transparent 65%);animation:floatMid 18s ease-in-out infinite}.bg-grid{position:fixed;inset:0;pointer-events:none;z-index:1;background-image:radial-gradient(circle at 20% 30%,rgba(108,60,225,.1) 0px,transparent 3px),radial-gradient(circle at 75% 20%,rgba(6,182,212,.08) 0px,transparent 4px),radial-gradient(circle at 60% 70%,rgba(139,92,246,.07) 0px,transparent 5px),radial-gradient(circle at 30% 80%,rgba(245,158,11,.05) 0px,transparent 4px),radial-gradient(circle,rgba(108,60,225,.06) 1px,transparent 1px);background-size:100% 100%,100% 100%,100% 100%,100% 100%,32px 32px;mask-image:radial-gradient(ellipse 75% 75% at 50% 40%,black 20%,transparent 72%);-webkit-mask-image:radial-gradient(ellipse 75% 75% at 50% 40%,black 20%,transparent 72%)}.bg-decor{position:fixed;inset:0;pointer-events:none;z-index:1;overflow:hidden}.bg-decor:before{content:"";position:absolute;top:12%;right:15%;width:80px;height:80px;border-radius:50%;background:radial-gradient(circle,rgba(168,85,247,.15) 0%,transparent 70%);filter:blur(8px);animation:orbFloat1 10s ease-in-out infinite}.bg-decor:after{content:"";position:absolute;bottom:25%;left:8%;width:60px;height:60px;border-radius:50%;background:radial-gradient(circle,rgba(6,182,212,.12) 0%,transparent 70%);filter:blur(6px);animation:orbFloat2 12s ease-in-out infinite}.bg-lines{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}.bg-lines:before{content:"";position:absolute;top:18%;right:4%;width:350px;height:1.5px;background:linear-gradient(90deg,transparent,rgba(108,60,225,.2),transparent);transform:rotate(-12deg);animation:lineFloat1 14s ease-in-out infinite}.bg-lines:after{content:"";position:absolute;bottom:35%;left:2%;width:250px;height:1px;background:linear-gradient(90deg,transparent,rgba(6,182,212,.15),transparent);transform:rotate(8deg);animation:lineFloat2 16s ease-in-out infinite reverse}@keyframes floatBig{0%,to{transform:translate(0) scale(1) rotate(0)}25%{transform:translate(30px,-20px) scale(1.08) rotate(1deg)}50%{transform:translate(-15px,15px) scale(.95) rotate(-.5deg)}75%{transform:translate(-25px,-10px) scale(1.04) rotate(.5deg)}}@keyframes floatSlow{0%,to{transform:translate(0) scale(1)}33%{transform:translate(20px,-25px) scale(1.1)}66%{transform:translate(-30px,20px) scale(.92)}}@keyframes floatMid{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-20px,15px) scale(1.06)}}@keyframes orbFloat1{0%,to{transform:translate(0) scale(1);opacity:.6}50%{transform:translate(40px,-30px) scale(1.5);opacity:1}}@keyframes orbFloat2{0%,to{transform:translate(0) scale(1);opacity:.5}50%{transform:translate(-30px,20px) scale(1.4);opacity:.9}}@keyframes lineFloat1{0%,to{opacity:.3;transform:rotate(-12deg) translateY(0)}50%{opacity:.7;transform:rotate(-12deg) translateY(-25px)}}@keyframes lineFloat2{0%,to{opacity:.3;transform:rotate(8deg) translateY(0)}50%{opacity:.6;transform:rotate(8deg) translateY(20px)}}.app-shell{display:grid;grid-template-columns:260px minmax(0,1fr);min-height:100vh;position:relative;z-index:1}.sidebar{position:sticky;top:0;height:100vh;padding:24px 16px 20px;display:flex;flex-direction:column;gap:20px;background:#ffffffd9;backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);border-right:1px solid var(--border);z-index:100}.brand{display:flex;align-items:center;gap:12px;padding:0 4px 20px;border-bottom:1px solid var(--border-light)}.brand-mark{width:44px;height:44px;display:grid;place-items:center;flex-shrink:0;background:var(--gradient-brand);border-radius:14px;box-shadow:0 4px 16px #6366f133}.brand-mark svg{color:#fff;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.brand strong{display:block;color:var(--text-primary);font-size:19px;font-weight:800;letter-spacing:.5px}.brand strong .accent{background:var(--gradient-hero-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.brand span{display:block;margin-top:2px;color:var(--text-tertiary);font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase}.nav-list{display:grid;gap:2px;flex:1;overflow-y:auto}.nav-list button,.ghost-button,.primary-button,.wechat-button,.icon-button,.category-strip button{border:0;border-radius:var(--r-sm);min-height:42px;display:inline-flex;align-items:center;justify-content:center;gap:10px;white-space:nowrap;font-weight:500;transition:all .2s var(--ease-out)}.nav-list button{justify-content:flex-start;padding:0 14px;color:var(--text-secondary);background:transparent;font-size:14px;border-radius:10px}.nav-list button:hover{color:var(--text-primary);background:var(--bg-subtle)}.nav-list button.active{color:var(--accent);background:var(--accent-soft);font-weight:600}.nav-list button.active svg{color:var(--accent)}.side-panel{margin-top:auto;display:flex;gap:12px;padding:14px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg-subtle);align-items:center}.side-panel svg{color:var(--accent-light);flex-shrink:0}.side-panel .avatar{width:38px;height:38px;display:grid;place-items:center;flex-shrink:0;color:#fff;background:var(--gradient-brand);border-radius:50%}.side-panel strong{display:block;color:var(--text-primary);font-size:13px}.side-panel p{margin-top:3px;color:var(--text-tertiary);font-size:11px;line-height:1.5}.level-tag{display:inline-block;padding:1px 7px;border-radius:10px;font-size:10px;font-weight:700;background:var(--gradient-brand);color:#fff}.primary-button{padding:0 20px;color:#fff;background:var(--gradient-brand);font-weight:600;font-size:14px;border-radius:var(--r-sm);box-shadow:0 2px 8px #6366f133;transition:all .2s var(--ease-out)}.primary-button:hover{box-shadow:0 4px 16px #6366f14d;transform:translateY(-1px)}.primary-button:active{transform:translateY(0);box-shadow:0 1px 4px #6366f126}.ghost-button{padding:0 16px;color:var(--text-secondary);background:transparent;font-size:13px}.ghost-button:hover{color:var(--text-primary);background:var(--bg-subtle)}.icon-button{width:42px;height:42px;padding:0;color:var(--text-secondary);background:transparent;border-radius:var(--r-sm)}.icon-button:hover{color:var(--text-primary);background:var(--bg-subtle)}.icon-button.favorited svg{fill:#ef4444;color:#ef4444}.wechat-button{padding:0 16px;color:var(--accent);background:var(--accent-soft);font-size:13px}.wechat-button:hover{background:#6366f11a}.checkin-btn{width:100%;padding:10px 16px;color:#fff;background:var(--gradient-success);border:0;border-radius:var(--r-sm);font-weight:600;font-size:13px;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all .2s var(--ease-out)}.checkin-btn:hover{box-shadow:0 4px 14px #10b98140;transform:translateY(-1px)}.checkin-done-btn{width:100%;padding:10px 16px;color:var(--text-tertiary);background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--r-sm);font-weight:600;font-size:13px;display:flex;align-items:center;justify-content:center;gap:8px;cursor:not-allowed}.main{min-width:0;padding:24px 36px 80px}.topbar{display:flex;align-items:center;gap:20px;margin-bottom:28px;position:sticky;top:0;z-index:50;padding:12px 0;background:#f8fafcd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.search-wrap{flex:1;display:flex;align-items:center;gap:12px;padding:0 20px;background:var(--bg-surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-xs);transition:all .2s var(--ease-out)}.search-wrap:focus-within{border-color:var(--border-focus);box-shadow:0 0 0 4px #6366f10f}.search-wrap svg{color:var(--text-tertiary);flex-shrink:0}.search-wrap input{flex:1;border:0;outline:none;padding:13px 0;background:transparent;color:var(--text-primary);font-size:14px}.search-wrap input::placeholder{color:var(--text-muted)}.top-actions{display:flex;align-items:center;gap:8px}.notif-bell{position:relative}.notif-badge{position:absolute;top:4px;right:4px;width:18px;height:18px;display:flex;align-items:center;justify-content:center;background:var(--danger);color:#fff;font-size:10px;font-weight:700;border-radius:50%;border:2px solid #fff}.hero-band{position:relative;display:grid;grid-template-columns:1fr 380px;gap:48px;padding:48px 44px;margin-bottom:32px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-sm);overflow:hidden}.hero-decor{position:absolute;pointer-events:none}.hero-decor-grid{top:0;right:0;width:380px;height:100%;background:radial-gradient(ellipse at center,rgba(99,102,241,.04) 0%,transparent 70%)}.hero-decor-dots{top:15%;right:22%;width:180px;height:180px;background-image:radial-gradient(circle,rgba(99,102,241,.1) 1.5px,transparent 1.5px);background-size:20px 20px;border-radius:50%;animation:drift1 15s ease-in-out infinite}.hero-decor-line{bottom:0;left:0;width:100%;height:2px;background:var(--gradient-aurora);opacity:.5}.hero-copy{display:flex;flex-direction:column;justify-content:center;gap:16px}.eyebrow{display:inline-flex;align-items:center;gap:6px;color:var(--accent);font-size:13px;font-weight:600;padding:6px 14px;background:var(--accent-soft);border-radius:20px;width:fit-content}.hero-name{font-size:14px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--text-tertiary)}.hero-copy h1{font-size:42px;font-weight:900;line-height:1.2;letter-spacing:-.5px;color:var(--text-primary)}.hero-copy h1 span{background:var(--gradient-hero-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-copy>p{font-size:15px;line-height:1.7;color:var(--text-secondary);max-width:480px}.hero-actions{display:flex;gap:12px;margin-top:4px}.hero-visual{background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--r-lg);padding:24px;display:flex;flex-direction:column;gap:16px;position:relative;z-index:1}.visual-head{display:flex;flex-direction:column;gap:4px}.visual-head span{color:var(--text-tertiary);font-size:12px;font-weight:500;display:flex;align-items:center;gap:6px}.visual-head strong{color:var(--text-primary);font-size:16px;font-weight:700}.visual-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.metric-card{padding:16px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-sm);display:flex;flex-direction:column;gap:4px}.metric-card.compact{padding:12px 14px}.metric-card span{color:var(--text-tertiary);font-size:11px;font-weight:500}.metric-card strong{color:var(--text-primary);font-size:28px;font-weight:800;letter-spacing:-1px}.metric-card small{color:var(--text-tertiary);font-size:11px;display:flex;align-items:center;gap:4px}.metric-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.terminal-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:linear-gradient(135deg,#6366f10f,#06b6d40a);border:1px solid var(--border-glow);border-radius:var(--r-sm)}.terminal-card p{color:var(--accent);font-family:Space Mono,monospace;font-size:13px;font-weight:600}.terminal-card span{color:var(--text-tertiary);font-size:11px}.category-strip{display:flex;gap:6px;margin-bottom:20px;flex-wrap:wrap}.category-strip button{padding:8px 18px;background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border);border-radius:10px;font-size:13px;font-weight:500}.category-strip button:hover{color:var(--text-primary);border-color:var(--text-muted)}.category-strip button.active{color:#fff;background:var(--gradient-brand);border-color:transparent;box-shadow:0 2px 10px #6366f140}.sort-bar{display:flex;align-items:center;gap:6px;margin-bottom:24px}.sort-bar span{color:var(--text-tertiary);font-size:13px;margin-right:6px}.sort-bar button{padding:6px 14px;background:transparent;color:var(--text-tertiary);border:0;border-radius:8px;font-size:13px}.sort-bar button:hover{color:var(--text-primary)}.sort-bar button.active-sort{color:var(--accent);background:var(--accent-soft);font-weight:600}.tool-grid-section{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.tool-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;cursor:pointer;transition:all .3s var(--ease-out);box-shadow:var(--shadow-xs)}.tool-card:hover{border-color:var(--border-glow);box-shadow:var(--shadow-card-hover);transform:translateY(-3px)}.tool-card:active{transform:translateY(-1px)}.tool-card-cover{width:100%;height:180px;overflow:hidden;background:var(--bg-subtle);position:relative}.tool-card-cover img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease-out)}.tool-card:hover .tool-card-cover img{transform:scale(1.06)}.tool-card-cover:after{content:"";position:absolute;bottom:0;left:0;right:0;height:50px;background:linear-gradient(to top,var(--bg-surface) 0%,transparent 100%)}.tool-body{padding:14px 18px 18px}.tool-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:6px}.tool-title-row h2{font-size:16px;font-weight:700;color:var(--text-primary);line-height:1.3;flex:1}.tool-body>p{font-size:13px;line-height:1.5;color:var(--text-tertiary);margin-bottom:14px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.tool-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.meta-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:var(--bg-subtle);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s var(--ease-out)}.meta-btn:hover{color:var(--text-primary);border-color:var(--text-muted)}.meta-btn.fav-action.favorited{color:var(--warning);border-color:#f59e0b4d;background:var(--warning-soft)}.tool-category-tag{margin-left:auto;padding:4px 10px;background:var(--accent-soft);color:var(--accent);font-size:11px;font-weight:600;border-radius:6px}.tool-detail-page{max-width:960px;margin:0 auto}.back-link{display:inline-flex;align-items:center;gap:6px;padding:0;background:transparent;border:0;color:var(--text-tertiary);font-size:14px;cursor:pointer;margin-bottom:24px}.back-link:hover{color:var(--text-primary)}.tool-detail-hero{display:grid;grid-template-columns:1fr 1fr;gap:36px;margin-bottom:36px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:32px;box-shadow:var(--shadow-sm)}.tool-detail-cover{width:100%;aspect-ratio:16/10;border-radius:var(--r-md);overflow:hidden;background:var(--bg-subtle)}.tool-detail-cover img{width:100%;height:100%;object-fit:cover}.tool-detail-hero-info{display:flex;flex-direction:column;gap:14px}.tool-detail-category{display:inline-block;padding:6px 14px;background:var(--accent-soft);color:var(--accent);font-size:12px;font-weight:600;border-radius:8px;width:fit-content}.tool-detail-hero-info h1{font-size:30px;font-weight:800;letter-spacing:-.5px}.tool-detail-author{color:var(--text-tertiary);font-size:14px}.tool-detail-author button{color:var(--accent);background:transparent;border:0;cursor:pointer;font-weight:600}.tool-detail-author button:hover{text-decoration:underline}.tool-detail-stats{display:flex;gap:24px}.stat-item{display:flex;align-items:center;gap:6px;color:var(--text-secondary);font-size:14px}.stat-item strong{color:var(--text-primary)}.tool-detail-actions{display:flex;gap:12px;margin-top:8px}.tool-detail-actions .primary-button{padding:12px 28px;font-size:15px}.tool-detail-body{display:grid;grid-template-columns:1fr 300px;gap:28px}.detail-description{padding:24px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-secondary);font-size:14px;line-height:1.8}.detail-description h2,.detail-description h3,.detail-description h4{color:var(--text-primary);margin:16px 0 8px}.detail-description ul{padding-left:20px}.detail-description li{margin:4px 0}.detail-reviews{margin-top:24px;padding:24px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md)}.detail-reviews h3{font-size:18px;margin-bottom:16px}.review-form{display:flex;gap:10px;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--border)}.review-form select{padding:8px 12px;background:var(--bg-subtle);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:13px;cursor:pointer}.review-form input{flex:1;padding:8px 14px;background:var(--bg-subtle);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:13px}.review-form input:focus{border-color:var(--border-focus);outline:none}.review{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--border-light)}.review:last-child{border-bottom:0}.review .avatar{width:36px;height:36px;display:grid;place-items:center;flex-shrink:0;background:var(--bg-subtle);border-radius:50%;color:var(--text-tertiary)}.review strong{display:block;font-size:13px;margin-bottom:4px}.review strong span{color:var(--warning);margin-left:6px}.review p{color:var(--text-secondary);font-size:13px;line-height:1.5}.tool-detail-sidebar .sidebar-card{padding:24px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md)}.tool-detail-sidebar h4{font-size:16px;margin-bottom:16px}.info-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border-light);font-size:13px}.info-row:last-child{border-bottom:0}.info-row span{color:var(--text-tertiary)}.info-row strong{color:var(--text-primary)}.notice-bar{padding:12px 20px;margin-bottom:20px;background:var(--accent-soft);border:1px solid var(--border-glow);border-radius:var(--r-sm);color:var(--accent);font-size:14px;font-weight:500}.pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:28px}.pagination button{padding:8px 20px;background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--r-sm);font-size:13px}.pagination button:hover:not(:disabled){color:var(--text-primary);border-color:var(--text-muted)}.pagination button:disabled{opacity:.4;cursor:not-allowed}.pagination span{color:var(--text-tertiary);font-size:13px}.modal-backdrop{position:fixed;inset:0;z-index:200;background:#0f172a4d;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{width:min(520px,92vw);max-height:85vh;overflow-y:auto;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:28px;box-shadow:var(--shadow-xl);animation:slideUp .25s var(--ease-out)}@keyframes slideUp{0%{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px}.modal-head span{display:flex;align-items:center;gap:6px;color:var(--accent);font-size:13px;font-weight:500}.modal-head h2{margin-top:4px;color:var(--text-primary);font-size:20px;font-weight:700}.modal-foot{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-grid label{display:grid;gap:6px}.form-grid label.wide{grid-column:1 / -1}label{display:block;color:var(--text-secondary);font-size:13px;font-weight:600}input,select,textarea{padding:10px 14px;background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-primary);font-size:14px;transition:border-color .15s var(--ease-out),box-shadow .15s var(--ease-out)}input:focus,select:focus,textarea:focus{border-color:var(--border-focus);outline:none;box-shadow:0 0 0 3px #6366f10f}.form-error{padding:10px 14px;margin-top:12px;background:var(--danger-soft);border:1px solid rgba(239,68,68,.2);border-radius:var(--r-sm);color:var(--danger);font-size:13px}.form-hint{padding:10px 14px;margin-top:12px;background:var(--accent-2-soft);border:1px solid rgba(6,182,212,.15);border-radius:var(--r-sm);color:#0891b2;font-size:13px}.auth-tabs{display:flex;gap:0;margin-bottom:20px;border:1px solid var(--border);border-radius:var(--r-sm);overflow:hidden}.auth-tab{flex:1;padding:10px;background:transparent;color:var(--text-tertiary);border:0;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s var(--ease-out)}.auth-tab.active{background:var(--accent-soft);color:var(--accent)}.auth-tab:not(:last-child){border-right:1px solid var(--border)}.auth-form{display:grid;gap:14px}.auth-form input{width:100%}.code-row>div{display:flex;gap:8px;margin-top:6px}.code-button{padding:0 16px;background:var(--accent-soft);color:var(--accent);border:0;border-radius:var(--r-sm);font-size:13px;font-weight:500;white-space:nowrap;cursor:pointer}.code-button:disabled{opacity:.5;cursor:not-allowed}.auth-switch{margin-top:18px;text-align:center;color:var(--text-tertiary);font-size:13px}.link-button{background:transparent;border:0;color:var(--accent);font-weight:600;cursor:pointer;font-size:13px}.link-button:hover{text-decoration:underline}.upload-file-label{padding:14px;background:var(--bg-subtle);border:2px dashed var(--border);border-radius:var(--r-sm);color:var(--text-tertiary);font-size:13px;font-weight:500;cursor:pointer;text-align:center;transition:all .2s var(--ease-out)}.upload-file-label:hover{border-color:var(--accent-light);color:var(--accent);background:var(--accent-soft)}.upload-success{display:inline-block;margin-left:8px;color:var(--success);font-weight:600}.wallet-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-top:24px}.balance-panel{padding:28px;background:var(--gradient-brand);border-radius:var(--r-lg);color:#fff;display:flex;flex-direction:column;gap:12px;box-shadow:0 4px 20px #6366f133}.balance-panel span{font-size:13px;opacity:.85}.balance-panel strong{font-size:42px;font-weight:900;letter-spacing:-1px}.balance-panel strong small{font-size:18px;font-weight:600;opacity:.8}.balance-panel p{font-size:13px;opacity:.85;line-height:1.6}.wallet-action{padding:24px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-xs)}.wallet-action svg{color:var(--accent);margin-bottom:12px}.wallet-action h2{font-size:16px;color:var(--text-primary);margin-bottom:6px}.wallet-action p{font-size:13px;color:var(--text-tertiary);line-height:1.5}.thread-list{display:grid;gap:8px}.thread{display:flex;align-items:center;gap:16px;padding:18px 20px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:all .2s var(--ease-out);box-shadow:var(--shadow-xs)}.thread:hover{border-color:var(--border-glow);box-shadow:var(--shadow-md)}.thread .avatar{width:40px;height:40px;display:grid;place-items:center;flex-shrink:0;background:var(--bg-subtle);border-radius:50%;color:var(--text-tertiary)}.thread>div:nth-child(2){flex:1;min-width:0}.thread h2{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:6px}.thread p{font-size:12px;color:var(--text-tertiary);display:flex;gap:12px;flex-wrap:wrap}.thread-cat{padding:2px 8px;background:var(--accent-soft);color:var(--accent);font-size:11px;font-weight:600;border-radius:4px}.thread-meta{display:flex;align-items:center;gap:10px;flex-shrink:0}.like-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;background:var(--bg-subtle);border:1px solid var(--border);border-radius:8px;color:var(--text-tertiary);font-size:12px;cursor:pointer;transition:all .15s var(--ease-out)}.like-btn:hover{color:#ef4444;border-color:#ef444433}.workspace-view{padding:0}.section-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.section-title span{display:flex;align-items:center;gap:6px;color:var(--accent);font-size:13px;font-weight:500}.section-title h1{font-size:24px;font-weight:800;margin-top:4px;letter-spacing:-.3px}.empty-state{display:flex;flex-direction:column;align-items:center;gap:12px;padding:64px 24px;color:var(--text-tertiary);text-align:center}.empty-state svg{opacity:.25}.empty-state p{font-size:14px}.post-detail{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:32px;margin-bottom:24px;box-shadow:var(--shadow-xs)}.post-header{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--border)}.post-header h1{font-size:26px;font-weight:800;margin:12px 0}.post-meta{display:flex;gap:16px;color:var(--text-tertiary);font-size:13px}.post-content{font-size:15px;line-height:1.8;color:var(--text-secondary)}.post-actions{display:flex;align-items:center;gap:16px;margin-top:24px;padding-top:24px;border-top:1px solid var(--border)}.comments-section{padding:24px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-xs)}.comments-section h2{font-size:18px;margin-bottom:20px}.comment-item{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--border-light)}.comment-item:last-child{border-bottom:0}.comment-item .avatar{width:34px;height:34px;display:grid;place-items:center;flex-shrink:0;background:var(--bg-subtle);border-radius:50%;color:var(--text-tertiary)}.comment-meta{font-size:12px;color:var(--text-tertiary);margin-bottom:4px}.comment-meta strong{color:var(--text-primary)}.comment-item p{font-size:14px;color:var(--text-secondary);line-height:1.6}.comment-form{display:flex;gap:10px;margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}.comment-form input{flex:1;padding:10px 14px;background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-primary);font-size:14px}.lb-grid{display:grid;gap:10px}.lb-card{display:flex;align-items:center;gap:16px;padding:18px 20px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:all .2s var(--ease-out);box-shadow:var(--shadow-xs)}.lb-card:hover{border-color:var(--border-glow);box-shadow:var(--shadow-md)}.lb-rank{width:42px;height:42px;display:grid;place-items:center;font-size:22px;flex-shrink:0}.lb-rank span{width:32px;height:32px;display:grid;place-items:center;background:var(--bg-subtle);border-radius:50%;font-size:14px;font-weight:700;color:var(--text-tertiary)}.lb-body{flex:1;min-width:0}.lb-body h3{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.lb-body p{font-size:12px;color:var(--text-tertiary)}.lb-meta{display:flex;gap:16px;margin-top:6px}.lb-meta span{font-size:12px;color:var(--text-secondary);display:flex;align-items:center;gap:4px}.admin-panel{display:grid;grid-template-columns:auto 1fr;min-height:calc(100vh - 120px);margin:-24px -36px -80px}.admin-sidebar{width:200px;padding:20px 12px;background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;gap:8px;transition:width .2s var(--ease-out)}.admin-sidebar.collapsed{width:60px}.admin-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:4px 8px 16px;border-bottom:1px solid var(--border);margin-bottom:4px}.admin-sidebar-header strong{font-size:15px;color:var(--text-primary)}.admin-nav{display:grid;gap:2px;flex:1}.admin-nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:transparent;border:0;border-radius:var(--r-sm);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s var(--ease-out)}.admin-nav-item:hover{color:var(--text-primary);background:var(--bg-subtle)}.admin-nav-item.active{color:var(--accent);background:var(--accent-soft)}.admin-sidebar-footer{display:flex;align-items:center;gap:8px;padding:12px 8px 0;border-top:1px solid var(--border)}.admin-content{padding:28px 32px;overflow-y:auto;background:var(--bg-root)}.admin-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.admin-topbar h2{font-size:22px;font-weight:700}.admin-topbar-actions{display:flex;align-items:center;gap:10px}.admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;margin-bottom:24px}.admin-card{padding:20px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);display:flex;flex-direction:column;gap:6px;box-shadow:var(--shadow-xs)}.admin-card svg{color:var(--accent)}.admin-card span{color:var(--text-tertiary);font-size:12px}.admin-card strong{color:var(--text-primary);font-size:26px;font-weight:800}.admin-card p{color:var(--text-tertiary);font-size:11px}.admin-section{margin-bottom:24px}.admin-section h3{font-size:16px;font-weight:700;margin-bottom:14px;color:var(--text-primary)}.admin-table{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}.table-head{display:grid;padding:12px 18px;background:var(--bg-subtle);font-size:12px;color:var(--text-tertiary);font-weight:600}.table-row{display:grid;padding:12px 18px;border-top:1px solid var(--border-light);font-size:13px;align-items:center;color:var(--text-secondary)}.table-row:hover{background:var(--bg-subtle)}.table-actions{display:flex;gap:6px}.approve-btn{padding:4px 12px;background:var(--success-soft);color:var(--success);border:1px solid rgba(16,185,129,.2);border-radius:6px;font-size:12px;font-weight:600;cursor:pointer}.reject-btn{padding:4px 12px;background:var(--danger-soft);color:var(--danger);border:1px solid rgba(239,68,68,.2);border-radius:6px;font-size:12px;font-weight:600;cursor:pointer}.status-label{padding:2px 10px;border-radius:6px;font-size:11px;font-weight:600}.status-label.approved{background:var(--success-soft);color:var(--success)}.status-label.rejected{background:var(--danger-soft);color:var(--danger)}.author-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;margin-bottom:24px}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:28px}.settings-card{padding:24px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-xs)}.settings-card h2{font-size:18px;margin-bottom:16px}.settings-card label{margin-bottom:12px;display:block}.settings-card input{width:100%;margin-top:6px}.settings-card .primary-button,.settings-card .ghost-button{margin-top:8px}.account-section-title{font-size:16px;font-weight:700;margin:28px 0 14px}.tool-list{display:grid;grid-template-columns:repeat(2,minmax(270px,1fr));gap:20px}.tool-list .tool-card img{width:100%;height:160px;object-fit:cover;background:var(--bg-subtle)}.forum-list{display:grid;gap:12px}.forum-card{padding:22px 24px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:all .2s var(--ease-out);box-shadow:var(--shadow-xs)}.forum-card:hover{border-color:var(--border-glow);box-shadow:var(--shadow-md)}.forum-card-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.forum-card-header strong{font-size:16px;font-weight:700;color:var(--text-primary)}.forum-card p{font-size:13px;color:var(--text-tertiary);line-height:1.5}.forum-card-meta{display:flex;align-items:center;gap:14px;margin-top:12px;font-size:12px;color:var(--text-tertiary)}.badge{padding:2px 8px;background:var(--accent-soft);color:var(--accent);font-size:11px;font-weight:600;border-radius:4px}.article-page{max-width:780px;margin:0 auto}.article-page-header{margin-bottom:32px;text-align:center}.article-page-header h1{font-size:32px;font-weight:900;letter-spacing:-1px;margin-bottom:16px}.article-page-meta{display:flex;align-items:center;justify-content:center;gap:16px;color:var(--text-tertiary);font-size:13px}.article-page-content{font-size:16px;line-height:2;color:var(--text-secondary)}.article-page-content h2,.article-page-content h3{color:var(--text-primary);margin:28px 0 14px}.article-page-content p{margin-bottom:14px}.recharge-modal{width:min(480px,92vw)}.recharge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;margin-bottom:16px}.recharge-card{padding:16px;background:var(--bg-subtle);border:2px solid var(--border);border-radius:var(--r-md);text-align:center;cursor:pointer;transition:all .2s var(--ease-out)}.recharge-card:hover{border-color:var(--text-muted)}.recharge-card.selected{border-color:var(--accent);background:var(--accent-soft)}.recharge-card strong{display:block;font-size:22px;color:var(--text-primary);margin-bottom:4px}.recharge-card span{display:block;font-size:16px;font-weight:700;color:var(--accent);margin-bottom:4px}.recharge-card small{font-size:11px;color:var(--text-tertiary)}.payment-methods{padding:16px;background:var(--bg-subtle);border-radius:var(--r-md)}.payment-option{display:flex;align-items:center;gap:8px;padding:8px;cursor:pointer}.payment-option input[type=radio]{width:auto;accent-color:var(--accent)}.site-footer{grid-column:1 / -1;display:flex;align-items:center;justify-content:center;gap:20px;padding:20px 32px;border-top:1px solid var(--border);font-size:12px;color:var(--text-tertiary);flex-wrap:wrap;background:var(--bg-surface)}.site-footer a{color:var(--text-tertiary);text-decoration:none}.site-footer a:hover{color:var(--text-secondary)}.cookie-banner{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:300;display:flex;align-items:center;gap:16px;padding:14px 22px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);font-size:13px;color:var(--text-secondary);max-width:600px}.cookie-banner button{padding:8px 20px;background:var(--gradient-brand);color:#fff;border:0;border-radius:var(--r-sm);font-weight:600;font-size:13px;cursor:pointer;white-space:nowrap}.notif-dropdown{position:absolute;top:100%;right:0;width:360px;max-height:420px;overflow-y:auto;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-xl);z-index:150;margin-top:8px}.notif-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg-surface);z-index:1}.notif-head strong{font-size:14px}.notif-list{padding:8px}.notif-empty{padding:32px 16px;text-align:center;color:var(--text-tertiary);font-size:13px;line-height:1.6}.notif-item{display:flex;gap:12px;padding:14px;border-radius:var(--r-sm);transition:background .15s var(--ease-out)}.notif-item:hover{background:var(--bg-subtle)}.notif-item.unread{background:var(--accent-soft)}.notif-icon{font-size:22px;flex-shrink:0}.notif-item strong{display:block;font-size:13px;margin-bottom:2px}.notif-item p{font-size:12px;color:var(--text-tertiary);line-height:1.4}.notif-item span{font-size:11px;color:var(--text-tertiary);margin-top:4px;display:block}.admin-login{max-width:480px;margin:64px auto}.admin-login-form{display:grid;gap:14px;padding:24px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md)}.admin-login-form input{width:100%}.login-hint{margin-top:16px;text-align:center;color:var(--text-tertiary);font-size:12px}.secondary-button{padding:0 20px;background:var(--bg-subtle);color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--r-sm);font-size:14px;font-weight:500;cursor:pointer;min-height:42px;display:inline-flex;align-items:center;justify-content:center}.secondary-button:hover{background:var(--bg-hover);color:var(--text-primary)}.card-press:active{transform:scale(.98)}.admin-notice{padding:6px 12px;background:var(--accent-soft);color:var(--accent);font-size:12px;border-radius:6px;cursor:pointer}.loading-text{padding:32px;text-align:center;color:var(--text-tertiary);font-size:14px}.qr-code-container img{border-radius:12px}.admin-user-badge{font-size:12px;color:var(--text-tertiary)}@media(max-width:1024px){.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;left:0;transform:translate(-100%);transition:transform .3s var(--ease-out)}.sidebar.open{transform:translate(0)}.main{padding:16px 20px 60px}.hero-band{grid-template-columns:1fr;padding:32px 24px}.tool-detail-hero,.tool-detail-body{grid-template-columns:1fr}.tool-grid-section{grid-template-columns:repeat(auto-fill,minmax(230px,1fr))}}@media(max-width:640px){.tool-grid-section{grid-template-columns:1fr}.search-wrap input{font-size:13px}.hero-copy h1{font-size:28px}.tool-list,.settings-grid{grid-template-columns:1fr}}.ai-review-container{display:flex;flex-direction:column;gap:16px}.ai-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.ai-tabs{display:flex;gap:8px;align-items:center}.ai-tab{padding:8px 16px;border:1px solid var(--border);background:var(--bg-primary);border-radius:8px;cursor:pointer;font-size:.9rem;display:flex;align-items:center;gap:6px;transition:all .2s}.ai-tab:hover{background:var(--bg-secondary)}.ai-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.ai-tab-badge{background:#dc2626;color:#fff;border-radius:10px;padding:1px 7px;font-size:.7rem;font-weight:700}.ai-refresh-btn{margin-left:auto;padding:8px;border:1px solid var(--border);border-radius:8px;background:var(--bg-primary);cursor:pointer;display:flex;align-items:center}.ai-detail-container{display:flex;flex-direction:column;gap:16px}.ai-back-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border:1px solid var(--border);border-radius:6px;background:var(--bg-primary);cursor:pointer;font-size:.85rem;width:fit-content}.ai-back-btn:hover{background:var(--bg-secondary)}.ai-detail-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:12px}.ai-detail-header h2{margin:0;font-size:1.3rem}.ai-detail-layout{display:grid;grid-template-columns:2fr 1fr;gap:16px}@media(max-width:900px){.ai-detail-layout{grid-template-columns:1fr}}.ai-detail-left,.ai-detail-right{display:flex;flex-direction:column;gap:16px}.ai-markdown-preview{line-height:1.6;font-size:.9rem;color:var(--text-primary)}.ai-markdown-preview h1,.ai-markdown-preview h2,.ai-markdown-preview h3{color:var(--text-primary)}.ai-tag{display:inline-block;padding:2px 10px;border-radius:12px;background:var(--bg-secondary);font-size:.75rem;color:var(--text-secondary);border:1px solid var(--border)}.ai-detail-actions{display:flex;gap:12px;padding:16px 0;border-top:1px solid var(--border)}.admin-action-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border:1px solid var(--border);border-radius:6px;background:var(--bg-primary);cursor:pointer;font-size:.8rem;transition:all .15s}.admin-action-btn:hover{background:var(--bg-secondary)}.admin-action-btn.small{padding:4px 8px;font-size:.75rem}.admin-action-btn.approve{border-color:#059669;color:#059669}.admin-action-btn.approve:hover{background:#d1fae5}.admin-action-btn.reject{border-color:#dc2626;color:#dc2626}.admin-action-btn.reject:hover{background:#fee2e2}.admin-action-btn:disabled{opacity:.5;cursor:not-allowed}.ai-stat-card{padding:16px;min-width:140px;transition:transform .15s,box-shadow .15s}.ai-stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.ai-stat-icon{font-size:1.4rem;margin-bottom:4px}.ai-stat-value{font-size:1.5rem;font-weight:700}.ai-stat-label{font-size:.8rem;color:var(--text-tertiary)}.ai-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.ai-toolbar-right{display:flex;gap:8px;align-items:center}.ai-trigger-toggle{display:inline-flex;align-items:center;gap:4px;padding:8px 14px;border:1px dashed var(--accent);border-radius:8px;background:transparent;color:var(--accent);cursor:pointer;font-size:.8rem;font-weight:600;transition:all .15s}.ai-trigger-toggle:hover,.ai-trigger-toggle.active{background:var(--accent);color:#fff;border-style:solid}.ai-trigger-panel{border:1px solid var(--border);border-radius:10px;overflow:hidden;animation:aiFadeIn .2s ease}@keyframes aiFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.ai-trigger-header{padding:10px 16px;background:var(--bg-secondary);font-weight:600;font-size:.9rem;display:flex;align-items:center;gap:8px}.ai-trigger-body{padding:12px 16px;display:flex;gap:10px;flex-wrap:wrap}.ai-trigger-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border:1px solid var(--border);border-radius:8px;background:var(--bg-primary);cursor:pointer;font-size:.85rem;transition:all .15s}.ai-trigger-btn:hover{background:var(--bg-secondary);border-color:var(--accent);color:var(--accent)}.ai-trigger-btn:disabled{opacity:.5;cursor:not-allowed}.ai-filters-bar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.ai-search-box{display:flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--border);border-radius:8px;background:var(--bg-primary);flex:1;min-width:180px;max-width:320px}.ai-search-box input{border:none;outline:none;background:transparent;color:var(--text-primary);font-size:.85rem;width:100%}.ai-filter-select{padding:7px 10px;border:1px solid var(--border);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:.85rem;cursor:pointer;outline:none}.ai-filter-select:focus{border-color:var(--accent)}.ai-clear-filter{padding:6px 12px;border:none;background:transparent;color:var(--accent);cursor:pointer;font-size:.8rem}.ai-batch-bar{display:flex;align-items:center;gap:10px;padding:10px 16px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;font-size:.85rem;animation:aiFadeIn .15s ease}.ai-checkbox-btn{border:none;background:transparent;cursor:pointer;padding:2px;color:var(--text-tertiary);display:flex;align-items:center;transition:color .15s}.ai-checkbox-btn:hover{color:var(--accent)}.ai-row-selected{background:#eff6ff!important}.ai-pagination{display:flex;align-items:center;gap:4px;justify-content:center;padding:16px 0 8px}.ai-pagination button{padding:6px 12px;border:1px solid var(--border);border-radius:6px;background:var(--bg-primary);cursor:pointer;font-size:.85rem;color:var(--text-primary);transition:all .15s}.ai-pagination button:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--accent)}.ai-pagination button.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:700}.ai-pagination button:disabled{opacity:.4;cursor:not-allowed}.ai-table-footer{text-align:center;font-size:.8rem;color:var(--text-tertiary);padding-top:4px}.ai-empty-state{text-align:center;padding:48px 20px;color:var(--text-tertiary)}.ai-empty-state p{margin:8px 0 0}.ai-empty-sm{padding:16px;text-align:center;color:var(--text-tertiary);font-size:.85rem}.ai-loading{text-align:center;padding:32px;color:var(--text-tertiary);font-size:.9rem}.ai-source-tag{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.75rem;background:var(--bg-secondary);border:1px solid var(--border)}.ai-pulse-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#f59e0b;margin-left:6px;animation:aiPulse 1.2s ease-in-out infinite}@keyframes aiPulse{0%,to{opacity:1}50%{opacity:.3}}.ai-workflow-row.expanded{background:var(--bg-subtle)}.ai-workflow-detail{padding:16px 20px;background:var(--bg-subtle);border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:16px;animation:aiFadeIn .2s ease}.ai-sub-section h4{display:flex;align-items:center;gap:6px;margin:0 0 10px;font-size:.85rem;color:var(--text-secondary)}.ai-mini-table{border:1px solid var(--border);border-radius:6px;overflow:hidden;font-size:.8rem}.ai-mini-head,.ai-mini-row{display:grid;grid-template-columns:1.5fr .8fr 1.5fr 1.5fr 1.5fr;gap:8px;padding:6px 12px;align-items:center}.ai-mini-head{background:var(--bg-secondary);font-weight:600;color:var(--text-secondary);font-size:.75rem}.ai-mini-row{border-top:1px solid var(--border)}.ai-mini-row:hover{background:var(--bg-primary)}.ai-discovery-chips{display:flex;flex-wrap:wrap;gap:8px}.ai-discovery-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border:1px solid var(--border);border-radius:16px;font-size:.8rem;background:var(--bg-primary)}.ai-log-list{max-height:200px;overflow-y:auto;border:1px solid var(--border);border-radius:6px;background:#1e1e2e;color:#cdd6f4;font-family:SF Mono,Cascadia Code,Fira Code,monospace;font-size:.75rem;padding:8px 0}.ai-log-line{display:flex;gap:8px;padding:2px 12px;line-height:1.6}.ai-log-line:hover{background:#ffffff0d}.ai-log-time{color:#6c7086;flex-shrink:0}.ai-log-level{flex-shrink:0;font-weight:600;min-width:32px;text-align:center}.ai-log-level.info{color:#89b4fa}.ai-log-level.warn{color:#f9e2af}.ai-log-level.error{color:#f38ba8}.ai-log-msg{word-break:break-all}.ai-link-item{display:flex;align-items:center;gap:4px;font-size:.85rem;margin-bottom:6px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite}.ai-review-table .table-head,.ai-review-table .table-row{grid-template-columns:32px 1.5fr .8fr .8fr .6fr .8fr 1fr}
