@import "https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,100..1000;1,9..40,100..1000&family=Noto+Sans+SC:wght@300;400;500;600;700&family=Space+Mono:wght@400;700&display=swap";.login-page{background:#070d1f;min-height:100vh;display:flex;overflow:hidden}.login-brand{background:linear-gradient(145deg,#050b1e 0%,#0c1b3a 40%,#132e5e 100%);flex:1;justify-content:center;align-items:center;padding:60px;display:flex;position:relative;overflow:hidden}.particle-canvas{z-index:1;position:absolute;inset:0}.brand-overlay{z-index:2;pointer-events:none;background:radial-gradient(60% 50% at 30%,#050b1e4d 0%,#0000 100%),radial-gradient(40% 60% at 70% 80%,#3470ff14 0%,#0000 100%),linear-gradient(#0000 0%,#050b1e66 100%);position:absolute;inset:0}.float-tags{z-index:3;pointer-events:none;position:absolute;inset:0;overflow:hidden}.float-tag{letter-spacing:.05em;color:var(--tag-color);background:color-mix(in srgb, var(--tag-color) 12%, transparent);border:1px solid color-mix(in srgb, var(--tag-color) 25%, transparent);white-space:nowrap;opacity:0;border-radius:100px;align-items:center;gap:6px;padding:5px 14px;font-size:.7rem;font-weight:600;animation:12s ease-in-out infinite floatTag;display:inline-flex;position:absolute}.float-tag-dot{background:var(--tag-color);width:5px;height:5px;box-shadow:0 0 6px var(--tag-color);border-radius:50%}.float-tag:first-child{animation-name:floatPath1;top:15%}.float-tag:nth-child(2){animation-name:floatPath2;top:35%}.float-tag:nth-child(3){animation-name:floatPath3;top:55%}.float-tag:nth-child(4){animation-name:floatPath4;top:75%}.float-tag:nth-child(5){animation-name:floatPath5;top:25%}.float-tag:nth-child(6){animation-name:floatPath6;top:65%}@keyframes floatPath1{0%,to{opacity:0;left:-120px;transform:translateY(0)}15%{opacity:.7}50%{opacity:.5;left:60%;transform:translateY(-20px)}85%{opacity:.7}95%{opacity:0;left:110%}}@keyframes floatPath2{0%,to{opacity:0;left:110%;transform:translateY(0)}15%{opacity:.6}50%{opacity:.5;left:30%;transform:translateY(15px)}85%{opacity:.6}95%{opacity:0;left:-120px}}@keyframes floatPath3{0%,to{opacity:0;left:-120px;transform:translateY(0)}20%{opacity:.7}50%{opacity:.4;left:45%;transform:translateY(-30px)}80%{opacity:.7}95%{opacity:0;left:105%}}@keyframes floatPath4{0%,to{opacity:0;left:105%;transform:translateY(0)}20%{opacity:.5}50%{opacity:.4;left:20%;transform:translateY(25px)}80%{opacity:.5}95%{opacity:0;left:-120px}}@keyframes floatPath5{0%,to{opacity:0;left:-100px;transform:translateY(0)}10%{opacity:.6}50%{opacity:.35;left:70%;transform:translateY(-15px)}90%{opacity:.6}95%{opacity:0;left:110%}}@keyframes floatPath6{0%,to{opacity:0;left:110%;transform:translateY(0)}10%{opacity:.6}50%{opacity:.35;left:15%;transform:translateY(20px)}90%{opacity:.6}95%{opacity:0;left:-100px}}.brand-content{z-index:5;max-width:520px;position:relative}.brand-badge{color:#00e5a0;letter-spacing:.18em;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00e5a00f;border:1px solid #00e5a066;border-radius:100px;margin-bottom:32px;padding:6px 18px;font-family:Space Mono,monospace;font-size:.68rem;font-weight:700;display:inline-block}.brand-title{color:#fff;letter-spacing:-.02em;margin-bottom:24px;font-family:DM Sans,Noto Sans SC,sans-serif;font-size:3.8rem;font-weight:800;line-height:1.08}.brand-accent{background:linear-gradient(135deg,#00e5a0 0%,#3470ff 50%,#5ef7c7 100%) 0 0/200% 200%;-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;animation:4s infinite gradientShift}@keyframes gradientShift{0%,to{background-position:0%}50%{background-position:100%}}.brand-desc{color:#ffffff8c;margin-bottom:48px;font-size:1rem;line-height:1.9}.brand-stats{gap:36px;display:flex}.brand-stat{flex-direction:column;min-width:100px;display:flex}.brand-stat-num{color:#fff;margin-bottom:4px;font-family:Space Mono,monospace;font-size:1.6rem;font-weight:700}.brand-stat-label{color:#fff6;letter-spacing:.03em;margin-bottom:10px;font-size:.72rem}.stat-bar{background:#ffffff14;border-radius:2px;width:100%;height:3px;overflow:hidden}.stat-bar-fill{background:linear-gradient(90deg,#3470ff,#5ef7c7);border-radius:2px;height:100%;animation:2s ease-out 1s both barGrow}.stat-bar-accent{background:linear-gradient(90deg,#00e5a0,#3470ff)}.stat-bar-warm{background:linear-gradient(90deg,#ff6b35,#ffb819)}@keyframes barGrow{0%{transform-origin:0;transform:scaleX(0)}to{transform-origin:0;transform:scaleX(1)}}.brand-ring{z-index:2;border:1px solid #3470ff14;border-radius:50%;animation:6s ease-in-out infinite ringPulse;position:absolute}.brand-ring-1{border-color:#00e5a00f;width:500px;height:500px;top:-120px;right:-100px}.brand-ring-2{width:700px;height:700px;animation-delay:3s;bottom:-250px;left:-200px}@keyframes ringPulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}.brand-pulse{z-index:2;background:radial-gradient(circle,#3470ff26 0%,#0000 70%);border-radius:50%;width:200px;height:200px;animation:3s ease-in-out infinite pulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes pulse{0%{box-shadow:0 0 #00c48c66}70%{box-shadow:0 0 0 6px #00c48c00}to{box-shadow:0 0 #00c48c00}}.data-flow-lines{z-index:4;pointer-events:none;width:120px;position:absolute;top:0;bottom:0;right:0;overflow:hidden}.data-flow-line{background:linear-gradient(#0000,#3470ff66,#00e5a04d,#0000);border-radius:2px;width:2px;height:60px;animation:4s linear infinite flowDown;position:absolute}.line-1{animation-delay:0s;right:30px}.line-2{height:80px;animation-delay:1.3s;right:60px}.line-3{height:50px;animation-delay:2.6s;right:90px}@keyframes flowDown{0%{opacity:0;top:-80px}10%{opacity:1}90%{opacity:1}to{opacity:0;top:110%}}.login-form-wrapper{background:linear-gradient(#0a1628 0%,#0f1f3d 50%,#0a1628 100%);justify-content:center;align-items:center;width:520px;padding:60px;display:flex;position:relative}.login-form-wrapper:before{content:"";pointer-events:none;background:radial-gradient(circle at 50% 30%,#3470ff0f 0%,#0000 60%),radial-gradient(circle at 50% 80%,#00e5a00a 0%,#0000 50%);position:absolute;inset:0}.login-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff0a;border:1px solid #ffffff14;border-radius:20px;width:100%;max-width:380px;padding:40px 36px;position:relative;box-shadow:0 8px 32px #0000004d,inset 0 0 0 1px #ffffff0d,0 0 80px #3470ff0d}.login-card:before{content:"";background:linear-gradient(90deg,#0000,#3470ff80,#00e5a066,#0000);height:1px;position:absolute;top:0;left:20%;right:20%}.login-card-header{text-align:center;margin-bottom:32px}.login-icon-circle{color:#3470ff;background:linear-gradient(135deg,#3470ff26,#00e5a01a);border:1px solid #3470ff33;border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 16px;display:flex}.login-card-header h2{color:#fff;margin-bottom:8px;font-family:DM Sans,Noto Sans SC,sans-serif;font-size:1.6rem;font-weight:700}.login-card-header p{color:#fff6;font-size:.85rem}.login-error{color:#ff6b7a;background:#ff3b5c1a;border:1px solid #ff3b5c40;border-radius:10px;align-items:center;gap:8px;margin-bottom:20px;padding:10px 16px;font-size:.82rem;display:flex}.login-card .form-group{margin-bottom:22px}.login-card .form-group label{color:#fff9;letter-spacing:.03em;margin-bottom:8px;font-size:.8rem;font-weight:600;display:block}.login-card .input-wrapper{position:relative}.login-card .input-wrapper svg{color:#ffffff40;pointer-events:none;z-index:2;transition:color .3s;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.login-card .input-wrapper .input{color:#fff;background:#ffffff0a;border:1.5px solid #ffffff14;border-radius:12px;outline:none;width:100%;padding:13px 16px 13px 44px;font-size:.9rem;transition:all .35s cubic-bezier(.4,0,.2,1)}.login-card .input-wrapper .input::placeholder{color:#fff3}.login-card .input-wrapper .input:focus{background:#3470ff0f;border-color:#3470ff99;box-shadow:0 0 0 3px #3470ff1f,0 0 20px #3470ff14}.login-card .input-wrapper:focus-within svg{color:#3470ff}.login-card .login-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3470ff 0%,#2a5fd9 100%);border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;height:50px;margin-top:8px;font-size:1rem;font-weight:600;transition:all .35s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.login-card .login-btn:before{content:"";opacity:0;z-index:-1;background:linear-gradient(135deg,#3470ff,#00e5a0);border-radius:14px;transition:opacity .35s;position:absolute;inset:-2px}.login-card .login-btn:hover:not(:disabled){transform:translateY(-2px)scale(1.02);box-shadow:0 8px 25px #3470ff66,0 0 60px #3470ff26}.login-card .login-btn:hover:not(:disabled):before{opacity:.3}.login-card .login-btn:active:not(:disabled){transform:translateY(0)scale(.98)}.login-card .login-btn:disabled{opacity:.6;cursor:not-allowed}.login-footer{text-align:center;margin-top:20px}.login-secure{color:#fff3;letter-spacing:.05em;align-items:center;gap:5px;font-size:.7rem;display:inline-flex}.login-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=1024px){.login-brand{display:none}.login-form-wrapper{background:linear-gradient(#070d1f 0%,#0f1f3d 100%);width:100%}}@media (width<=480px){.login-form-wrapper{padding:40px 24px}.login-card{padding:32px 24px}}.alert-bell{cursor:pointer;color:var(--text-color);border-radius:50%;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:flex;position:relative}.alert-bell:hover{background-color:var(--hover-color)}.alert-bell svg{width:20px;height:20px}.badge{color:#fff;text-align:center;background-color:#f43f5e;border:2px solid #fff;border-radius:10px;min-width:14px;padding:2px 6px;font-size:10px;font-weight:600;animation:2s infinite pulse-red;position:absolute;top:4px;right:4px}@keyframes pulse-red{0%{box-shadow:0 0 #f43f5e66}70%{box-shadow:0 0 0 4px #f43f5e00}to{box-shadow:0 0 #f43f5e00}}.alert-dropdown{border:1px solid var(--border-color);z-index:100;background:#fff;border-radius:12px;flex-direction:column;width:320px;margin-top:8px;display:flex;position:absolute;top:100%;right:0;overflow:hidden;box-shadow:0 10px 25px #0000001a}.alert-dropdown-header{border-bottom:1px solid var(--border-color);background:#f8fafc;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.alert-dropdown-header h4{color:var(--text-color);margin:0;font-size:14px;font-weight:600}.mark-all-btn{color:var(--primary-color);cursor:pointer;background:0 0;border:none;font-size:12px}.mark-all-btn:hover{text-decoration:underline}.alert-dropdown-body{max-height:300px;overflow-y:auto}.alert-dropdown-item{border-bottom:1px solid var(--border-color);cursor:pointer;gap:12px;padding:12px 16px;transition:background-color .2s;display:flex}.alert-dropdown-item:hover{background-color:#f1f5f9}.alert-item-icon{border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;display:flex}.alert-item-icon.warning{color:#d97706;background:#fef3c7}.alert-item-icon.critical{color:#e11d48;background:#ffe4e6}.alert-item-content{flex:1;min-width:0}.alert-item-title{color:var(--text-color);white-space:nowrap;text-overflow:ellipsis;margin:0 0 4px;font-size:13px;font-weight:500;overflow:hidden}.alert-item-meta{color:#64748b;justify-content:space-between;font-size:11px;display:flex}.alert-dropdown-footer{text-align:center;border-top:1px solid var(--border-color);color:var(--primary-color);cursor:pointer;background:#f8fafc;padding:10px;font-size:13px}.alert-dropdown-footer:hover{text-decoration:underline}.alert-empty{text-align:center;color:#64748b;padding:32px 16px;font-size:13px}.layout-app{background:var(--c-bg);height:100vh;display:flex;overflow:hidden}.layout-sidebar{background:var(--c-bg-sidebar);color:#fff;z-index:10;width:260px;transition:width var(--dur) var(--ease);flex-direction:column;flex-shrink:0;display:flex;position:relative;box-shadow:4px 0 24px #0c1b3a1a}.sidebar-brand{border-bottom:1px solid #ffffff0f;align-items:center;gap:12px;height:80px;padding:0 24px;display:flex}.sidebar-logo{background:var(--c-primary);color:#fff;width:32px;height:32px;box-shadow:var(--shadow-glow);border-radius:8px;justify-content:center;align-items:center;display:flex}.sidebar-title{font-family:var(--f-heading);letter-spacing:.05em;font-size:1.1rem;font-weight:700}.sidebar-nav{flex:1;padding:24px 16px;overflow-y:auto}.nav-group-label{font-family:var(--f-display);color:#fff6;text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px;padding:0 12px;font-size:.7rem}.nav-link{color:#ffffffa6;border-radius:var(--r-sm);transition:color var(--dur) var(--ease), background var(--dur) var(--ease);align-items:center;gap:12px;margin-bottom:8px;padding:12px 14px;font-size:.95rem;font-weight:500;display:flex;position:relative}.nav-link:hover{color:#fff;background:#ffffff0a}.nav-link.active{color:#fff;background:var(--c-bg-sidebar-hover)}.nav-link.active svg{color:var(--c-accent)}.nav-indicator{background:var(--c-accent);border-radius:0 3px 3px 0;width:3px;position:absolute;top:8px;bottom:8px;left:0;box-shadow:0 0 10px #00e5a066}.sidebar-footer{border-top:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding:20px;display:flex}.user-profile{align-items:center;gap:12px;display:flex;overflow:hidden}.avatar{border-radius:var(--r-sm);background:linear-gradient(135deg, var(--c-primary), #6366f1);width:40px;height:40px;font-family:var(--f-display);color:#fff;flex-shrink:0;justify-content:center;align-items:center;font-size:1.1rem;font-weight:700;display:flex}.user-info{white-space:nowrap;overflow:hidden}.user-name{text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.user-role{color:#ffffff73;font-size:.75rem}.btn-logout{color:#fff6;border-radius:var(--r-sm);transition:all var(--dur) var(--ease);padding:8px}.btn-logout:hover{color:var(--c-danger);background:#ff3b5c1a}.layout-main{flex-direction:column;flex:1;min-width:0;display:flex;position:relative;overflow:hidden}.layout-header{-webkit-backdrop-filter:blur(12px);z-index:5;background:#f3f6fbcc;border-bottom:1px solid #e2e8f480;justify-content:space-between;align-items:center;height:80px;padding:0 32px;display:flex;position:sticky;top:0}.header-breadcrumbs{font-family:var(--f-heading);color:var(--c-text);letter-spacing:-.01em;font-size:1.25rem;font-weight:700}.header-actions{align-items:center;gap:20px;display:flex}.enterprise-badge{box-shadow:var(--shadow-sm);background:#ffffffe0;border:1px solid #3470ff24;border-radius:999px;align-items:center;gap:10px;padding:8px 14px;display:flex}.enterprise-badge-label{letter-spacing:.06em;color:var(--c-text-secondary);text-transform:uppercase;font-size:.72rem;font-weight:700}.enterprise-badge-name{text-overflow:ellipsis;white-space:nowrap;max-width:none;color:var(--c-text);font-weight:700;overflow:hidden}.header-status{color:var(--c-success);background:var(--c-bg-card);box-shadow:var(--shadow-sm);border:1px solid var(--c-border);border-radius:100px;align-items:center;gap:8px;padding:6px 16px;font-size:.8rem;font-weight:600;display:flex}.status-dot{background:var(--c-success);border-radius:50%;width:6px;height:6px;animation:2s infinite pulse;box-shadow:0 0 0 2px #00c48c33}.header-date{color:var(--c-text-secondary);font-size:.85rem;font-family:var(--f-display)}.layout-content{flex-direction:column;flex:1;padding:24px 30px;display:flex;overflow:hidden}.page-wrapper{flex-direction:column;flex:1;width:100%;min-height:0;margin:0;display:flex;overflow-y:auto}.dashboard{flex-direction:column;gap:24px;display:flex}.dashboard-loading{justify-content:center;align-items:center;height:400px;display:flex}.skeleton-card{pointer-events:none}.skeleton-block{background:linear-gradient(90deg, var(--c-bg) 25%, #3470ff0a 50%, var(--c-bg) 75%);background-size:400% 100%;border-radius:6px;animation:1.8s ease-in-out infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.sentiment-page{flex-direction:column;gap:24px;display:flex}.sentiment-page .dashboard-grid{grid-template-columns:repeat(2,1fr)}.stat-cards{grid-template-columns:repeat(4,1fr);gap:24px;display:grid}.stat-card{align-items:center;gap:16px;padding:24px;display:flex;position:relative;overflow:hidden}.stat-icon{border-radius:var(--r-md);flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.stat-info{flex:1}.stat-label{color:var(--c-text-secondary);margin-bottom:4px;font-size:.85rem;font-weight:500}.stat-value{color:var(--c-text);font-size:1.75rem;font-weight:700;line-height:1}.stat-sparkline{background:radial-gradient(circle, var(--c-primary-glow) 0%, transparent 70%);opacity:.5;width:120px;height:80px;position:absolute;bottom:-20px;right:-20px}.dashboard-grid{grid-template-columns:repeat(3,1fr);grid-auto-rows:minmax(380px,auto);gap:24px;display:grid}.chart-card{flex-direction:column;padding:24px;display:flex}.trend-card{grid-column:span 2}.keyword-card{grid-column:span 1}.hot-posts-card{grid-column:span 2;padding:0}.card-title{color:var(--c-text);margin-bottom:24px;font-size:1rem;font-weight:700}.chart-wrapper{flex:1;min-height:0}.chart-legend{grid-template-columns:1fr 1fr;gap:12px;margin-top:24px;display:grid}.legend-item{color:var(--c-text-secondary);align-items:center;font-size:.85rem;display:flex}.legend-dot{border-radius:50%;width:8px;height:8px;margin-right:8px}.legend-val{color:var(--c-text);margin-left:auto;font-weight:700}.card-header{padding:24px 24px 0}.hot-post-list{padding:12px 24px 24px}.hot-post-item{border-bottom:1px dashed var(--c-border);align-items:center;gap:16px;padding:16px 0;display:flex}.hot-post-item:last-child{border-bottom:none}.hot-rank{border-radius:var(--r-sm);background:var(--c-bg);width:28px;height:28px;color:var(--c-text-secondary);font-family:var(--f-display);flex-shrink:0;justify-content:center;align-items:center;font-size:.9rem;font-weight:700;display:flex}.rank-1{color:#ff3b5c;background:#ffebee}.rank-2{color:#ff8b19;background:#fff4e5}.rank-3{color:#d4a017;background:#fffcf0}.hot-post-content{flex:1;min-width:0}.hot-post-title{color:var(--c-text);white-space:nowrap;text-overflow:ellipsis;margin-bottom:6px;font-weight:600;overflow:hidden}.hot-post-meta{color:var(--c-text-secondary);align-items:center;gap:12px;font-size:.75rem;display:flex}.hot-post-data{color:var(--c-accent-warm);flex-shrink:0;align-items:center;gap:6px;font-size:.9rem;font-weight:600;display:flex}@media (width<=1200px){.stat-cards{grid-template-columns:repeat(2,1fr)}.dashboard-grid{flex-direction:column;display:flex}}.post-list-page{flex-direction:column;flex:1;gap:24px;min-height:0;display:flex;overflow:hidden}.filter-card{padding:24px}.filter-form{flex-wrap:wrap;align-items:flex-end;gap:20px;display:flex}.filter-group{flex:1;min-width:240px}.filter-group label{color:var(--c-text-secondary);margin-bottom:8px;font-size:.85rem;font-weight:600;display:block}.list-input,.list-select{height:42px;padding:10px 14px}.list-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%236b7a99' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.filter-actions{gap:12px;display:flex}.list-btn-search,.list-btn-reset{height:42px}.list-card{flex-direction:column;flex:1;min-width:0;max-width:100%;min-height:0;display:flex;overflow:hidden}.list-header{padding:24px 24px 0}.list-count{color:var(--c-text-muted);margin-left:8px;font-size:.9rem;font-weight:400}.list-content{flex:1;min-width:0;padding:24px;overflow:hidden auto}.list-loading,.list-empty{height:300px;color:var(--c-text-muted);justify-content:center;align-items:center;display:flex}.data-list{flex-direction:column;min-width:0;display:flex}.list-item{border-bottom:1px solid var(--c-border);justify-content:space-between;align-items:center;min-width:0;padding:24px;transition:all .2s;display:flex}.list-item:hover{background:#3470ff05}.list-item:last-child{border-bottom:none}.list-item-main{flex-direction:column;flex:1;gap:12px;min-width:0;padding-right:32px;display:flex}.list-item-header-row{align-items:flex-start;gap:16px;min-width:0;display:flex}.list-item-cover{border-radius:var(--r-md);background-position:50%;background-size:cover;background-color:var(--c-bg);border:1px solid var(--c-bg);flex-shrink:0;width:120px;height:80px}.list-item-text-content{flex-direction:column;flex:1;gap:8px;min-width:0;display:flex}.list-item-snippet{color:var(--c-text-secondary);-webkit-line-clamp:2;text-overflow:ellipsis;-webkit-box-orient:vertical;font-size:.9rem;line-height:1.5;display:-webkit-box;overflow:hidden}.list-item-title{color:var(--c-text);white-space:nowrap;text-overflow:ellipsis;margin-bottom:0;font-size:1.1rem;font-weight:500;line-height:1.5;overflow:hidden}.list-item-link{color:inherit;text-decoration:none;transition:color .2s}.list-item-link:hover{color:var(--c-primary)}.list-item-meta{color:var(--c-text-secondary);flex-wrap:wrap;align-items:center;gap:20px;font-size:.85rem;display:flex}.meta-author,.data-date{align-items:center;gap:6px;display:flex}.data-date{font-family:var(--f-display)}.tag-semantic-positive{color:#10b981;background:#10b9811a}.tag-semantic-negative{color:#ef4444;background:#ef44441a}.tag-semantic-neutral{color:#6b7280;background:#6b72801a}.list-item-side{flex-shrink:0;align-items:center;display:flex}.meta-stats{color:var(--c-text-muted);font-size:.9rem;font-family:var(--f-display);gap:20px;display:flex}.meta-stats span{align-items:center;gap:6px;min-width:60px;display:flex}.list-pagination{border-top:1px solid var(--c-border);justify-content:center;align-items:center;gap:24px;width:100%;max-width:100%;padding:24px;display:flex}.page-info{color:var(--c-text-secondary);align-items:center;gap:8px;font-size:.9rem;display:flex}.pagination-numbers{align-items:center;gap:8px;display:flex}.page-num{width:36px;height:36px;color:var(--c-text-secondary);cursor:pointer;font-size:.9rem;font-weight:500;font-family:var(--f-display);background:0 0;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.page-num:hover:not(.page-ellipsis):not(.page-active){color:var(--c-primary);background:#3470ff0d}.page-active{background:var(--c-primary);color:#fff;box-shadow:0 4px 12px #3470ff33}.page-ellipsis{cursor:default;color:var(--c-text-muted)}.jump-input{text-align:center;border:1px solid var(--c-border);width:50px;height:32px;font-family:var(--f-display);background:var(--c-bg);color:var(--c-text);border-radius:6px;outline:none;padding:4px 8px;font-size:.9rem;transition:all .2s}.jump-input:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px #3470ff1a}.jump-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.jump-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.tag-aggregate{color:#7c3aed;white-space:nowrap;vertical-align:middle;background:linear-gradient(135deg,#8b5cf61f,#6366f11f);border-radius:20px;align-items:center;gap:4px;margin-left:10px;padding:3px 10px;font-size:.75rem;font-weight:600;animation:2s ease-in-out infinite pulse-badge;display:inline-flex}@keyframes pulse-badge{0%,to{box-shadow:0 0 #7c3aed26}50%{box-shadow:0 0 0 6px #7c3aed00}}.btn-expand-dups{color:#7c3aed;cursor:pointer;background:#7c3aed0f;border:1px dashed #7c3aed4d;border-radius:8px;align-self:flex-start;margin-top:8px;padding:6px 14px;font-size:.8rem;font-weight:500;transition:all .2s}.btn-expand-dups:hover:not(:disabled){background:#7c3aed1f;border-color:#7c3aed80}.btn-expand-dups:disabled{cursor:wait;opacity:.6}.duplicate-children{background:#7c3aed05;border-left:3px solid #7c3aed4d;border-radius:0 0 12px 12px;margin-left:24px;overflow:hidden}.duplicate-children-header{border-bottom:1px solid var(--c-border);padding:10px 20px}.duplicate-children-label{color:#7c3aed;font-size:.8rem;font-weight:600}.list-item-child{background:0 0;border-bottom-color:#7c3aed14!important;padding:16px 20px!important}.list-item-child .list-item-title{font-size:.95rem}.list-item-child .list-item-cover{width:80px;height:54px}.skeleton-list{flex-direction:column;gap:20px;padding:8px 0;display:flex}.skeleton-list-item{border-bottom:1px solid var(--c-border);padding:20px 0}.post-action-row{align-items:center;gap:10px;margin-top:8px;display:flex}.btn-graph-modal{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6366f1,#3b82f6);border:none;border-radius:8px;padding:6px 16px;font-size:.8rem;font-weight:600;transition:all .25s;box-shadow:0 2px 8px #6366f14d}.btn-graph-modal:hover{transform:translateY(-1px);box-shadow:0 4px 16px #6366f173}.graph-modal-overlay{z-index:9999;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000000b3;justify-content:center;align-items:center;padding:32px;display:flex;position:fixed;inset:0}.graph-modal-content{background:#111827;border:1px solid #6366f133;border-radius:20px;flex-direction:column;width:90vw;max-width:1200px;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 24px 80px #0009,0 0 60px #6366f126}.graph-modal-header{border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;padding:20px 28px;display:flex}.graph-modal-title{color:#f1f5f9;align-items:center;gap:12px;font-size:1.15rem;font-weight:700;display:flex}.graph-modal-badge{color:#818cf8;background:linear-gradient(135deg,#6366f133,#3b82f633);border-radius:20px;padding:4px 12px;font-size:.75rem;font-weight:600}.graph-modal-close{color:#94a3b8;cursor:pointer;background:0 0;border:1px solid #ffffff1a;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;transition:all .2s;display:flex}.graph-modal-close:hover{color:#fff;background:#ffffff1a}.graph-source-card{background:linear-gradient(135deg,#fbbf2414,#f59e0b0a);border-bottom:1px solid #fbbf2426;flex-wrap:wrap;align-items:center;gap:12px;padding:14px 28px;display:flex}.graph-source-badge{color:#fbbf24;white-space:nowrap;background:#fbbf2433;border-radius:6px;padding:3px 10px;font-size:.75rem;font-weight:700}.graph-source-title{color:#f1f5f9;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.9rem;font-weight:600;overflow:hidden}.graph-source-meta{color:#64748b;white-space:nowrap;font-size:.78rem}.graph-modal-body{flex:1;min-height:0;padding:8px;overflow:hidden}.graph-modal-loading{color:#94a3b8;flex-direction:column;justify-content:center;align-items:center;gap:16px;height:400px;font-size:.95rem;display:flex}.graph-modal-loading .spinner{border-color:#6366f1 #6366f133 #6366f133}.graph-modal-empty{color:#64748b;justify-content:center;align-items:center;height:400px;font-size:.95rem;display:flex}.heat-page{flex-direction:column;gap:20px;display:flex}.hm-tabs-bar{border:1px solid var(--c-border);background:#fff;border-radius:16px;gap:6px;width:fit-content;padding:5px;display:flex;box-shadow:0 2px 12px #1a26420a}.hm-tab-btn{cursor:pointer;color:var(--c-text-secondary);transition:all .3s var(--ease);background:0 0;border:none;border-radius:12px;align-items:center;gap:8px;padding:10px 28px;font-size:.88rem;font-weight:600;display:flex;position:relative}.hm-tab-btn:hover{color:var(--c-text);background:var(--c-bg)}.hm-tab-btn.active{background:var(--c-primary);color:#fff;box-shadow:0 4px 16px #3470ff59}.hm-tab-btn.active svg{stroke:#fff}.hm-match-count{color:#fff;text-align:center;background:#ff3b5c;border-radius:10px;min-width:22px;padding:2px 8px;font-size:.68rem;font-weight:700;line-height:1.2}.hm-tab-btn.active .hm-match-count{background:#ffffff4d}.hm-stats-strip{border:1px solid var(--c-border);background:#fff;border-radius:14px;align-items:center;gap:0;padding:12px 24px;display:flex;box-shadow:0 1px 4px #1a264208}.hm-strip-item{color:var(--c-text-secondary);align-items:center;gap:8px;padding:0 20px;font-size:.85rem;font-weight:500;display:flex}.hm-strip-item:first-child{padding-left:0}.hm-strip-item svg{stroke:var(--c-primary);flex-shrink:0}.hm-strip-item strong{color:var(--c-text);font-weight:700}.hm-strip-divider{background:var(--c-border);flex-shrink:0;width:1px;height:18px}.hm-grid{grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:20px;display:grid}.hm-platform-card{border:1px solid var(--c-border);transition:box-shadow .3s var(--ease), transform .3s var(--ease);background:#fff;border-radius:16px;position:relative;overflow:hidden}.hm-platform-card:hover{transform:translateY(-3px);box-shadow:0 8px 32px #1a26421a}.hm-card-accent{width:100%;height:4px}.hm-card-header{align-items:center;gap:12px;padding:16px 20px 12px;display:flex}.hm-platform-icon{width:36px;height:36px;transition:transform .3s var(--ease);background:#f8f9fc;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.hm-platform-card:hover .hm-platform-icon{transform:scale(1.08)}.hm-platform-name{color:var(--c-text);letter-spacing:.01em;flex:1;margin:0;font-size:.95rem;font-weight:700}.hm-topic-badge{color:var(--c-text-secondary);background:var(--c-bg);letter-spacing:.02em;border-radius:20px;padding:4px 12px;font-size:.72rem;font-weight:600}.hm-topic-list{padding:4px 12px 12px}.hm-topic-row{transition:background .2s var(--ease);border-radius:10px;align-items:flex-start;gap:10px;padding:9px 8px;display:flex}.hm-topic-row:hover{background:#f8f9fc}.hm-rank{width:24px;height:24px;font-size:.72rem;font-weight:800;font-family:var(--f-display);transition:transform .2s var(--ease);border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;display:flex}.hm-topic-row:hover .hm-rank{transform:scale(1.1)}.hm-topic-body{flex:1;min-width:0}.hm-topic-title{color:var(--c-text);text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.87rem;font-weight:600;line-height:1.45;display:-webkit-box;overflow:hidden}.hm-topic-title a{color:inherit;text-decoration:none;transition:color .15s}.hm-topic-title a:hover{color:var(--c-primary)}.hm-topic-meta{gap:14px;margin-top:4px;display:flex}.hm-meta-item{color:var(--c-text-muted);align-items:center;gap:4px;font-size:.72rem;font-weight:500;display:inline-flex}.hm-meta-item svg{stroke:var(--c-text-muted);opacity:.7}@media (width<=900px){.hm-grid{grid-template-columns:1fr}.hm-tabs-bar{width:100%}.hm-tab-btn{flex:1;justify-content:center;padding:10px 16px}.hm-stats-strip{flex-wrap:wrap;gap:8px}.hm-strip-divider{display:none}.hm-strip-item{padding:4px 12px}}.alerts-container{width:100%}.alerts-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;display:flex}.alerts-header h2{color:var(--text-color);margin:0;font-size:24px}.alerts-tabs{gap:32px;display:flex}.tab-item{color:#64748b;cursor:pointer;margin-bottom:-17px;padding-bottom:16px;font-size:16px;font-weight:500;transition:color .2s;position:relative}.tab-item:hover,.tab-item.active{color:var(--primary-color)}.tab-item.active:after{content:"";background-color:var(--primary-color);border-radius:2px 2px 0 0;height:2px;position:absolute;bottom:0;left:0;right:0}.btn-primary{background:var(--primary-color);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-size:14px;transition:opacity .2s}.btn-primary:hover{opacity:.9}.btn-secondary{border:1px solid var(--border-color);color:var(--text-color);cursor:pointer;background:#fff;border-radius:6px;padding:8px 16px;font-size:14px}.btn-secondary:hover{background:#f8fafc}.btn-text{color:var(--primary-color);cursor:pointer;background:0 0;border:none;font-size:13px;font-weight:500}.btn-text.danger{color:#e11d48}.btn-text:hover{opacity:.8;text-decoration:underline}.empty-state{border:1px dashed var(--border-color);text-align:center;background:#fff;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;padding:100px 0;display:flex}.empty-icon{margin-bottom:16px;font-size:48px}.empty-state h3{color:var(--text-color);margin:0 0 8px;font-size:18px}.empty-state p{color:#64748b;max-width:400px;margin:0 0 24px;font-size:14px}.rules-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px;display:grid}.rule-card{border:1px solid var(--border-color);background:#fff;border-radius:12px;flex-direction:column;padding:20px;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 1px 3px #0000000d}.rule-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a}.rule-card.inactive{opacity:.6;background:#f8fafc}.rule-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.rule-title{align-items:center;gap:8px;display:flex}.rule-title h4{color:var(--text-color);margin:0;font-size:16px;font-weight:600}.rule-icon{font-size:20px}.rule-card-body{flex:1}.rule-card-body p{color:#475569;margin:0 0 8px;font-size:14px}.rule-card-body .rule-meta{color:#94a3b8;margin-top:16px;font-size:12px}.rule-card-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:16px;margin-top:16px;padding-top:16px;display:flex}.switch{width:44px;height:24px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.slider{cursor:pointer;background-color:#cbd5e1;transition:all .4s;position:absolute;inset:0}.slider:before{content:"";background-color:#fff;width:18px;height:18px;transition:all .4s;position:absolute;bottom:3px;left:3px}input:checked+.slider{background-color:var(--primary-color)}input:checked+.slider:before{transform:translate(20px)}.slider.round{border-radius:24px}.slider.round:before{border-radius:50%}.drawer-overlay{z-index:1000;background:#0006;justify-content:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.drawer-content{background:#fff;flex-direction:column;width:500px;height:100vh;animation:.3s cubic-bezier(.16,1,.3,1) slideIn;display:flex;box-shadow:-4px 0 15px #0000001a}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:24px;display:flex}.drawer-header h3{margin:0;font-size:18px}.close-btn{cursor:pointer;color:#64748b;background:0 0;border:none;font-size:24px}.drawer-body{flex:1;padding:24px;overflow-y:auto}.form-group{flex-direction:column;margin-bottom:20px;display:flex}.form-group label{color:var(--text-color);margin-bottom:8px;font-size:14px;font-weight:500}.form-group input[type=text],.form-group input[type=number],.form-group select{border:1px solid var(--border-color);border-radius:6px;outline:none;padding:10px 12px;font-size:14px}.form-group input:focus,.form-group select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.helper-text{color:#64748b;margin:4px 0 0;font-size:12px}.form-error{color:#b91c1c;background:#fee2e2;border:1px solid #fca5a5;border-radius:6px;margin-bottom:20px;padding:12px;font-size:14px}.condition-box{border:1px solid var(--border-color);background:#f8fafc;border-radius:8px;margin-bottom:24px;padding:20px}.condition-box h4{color:#334155;margin:0 0 16px;font-size:14px}.form-row{gap:16px;display:flex}.form-row .form-group{flex:1}.drawer-footer{border-top:1px solid var(--border-color);background:#fff;justify-content:flex-end;gap:16px;padding:24px;display:flex}.timeline{flex-direction:column;display:flex}.timeline-item{padding-bottom:32px;padding-left:32px;position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-marker{z-index:2;width:12px;height:12px;box-shadow:0 0 0 2px var(--border-color);background:var(--primary-color);border:2px solid #fff;border-radius:50%;position:absolute;top:6px;left:0}.timeline-item.warning .timeline-marker{background:#f59e0b;box-shadow:0 0 0 2px #fef3c7}.timeline-item.critical .timeline-marker{background:#e11d48;animation:2s infinite pulse-critical;box-shadow:0 0 0 2px #ffe4e6}@keyframes pulse-critical{0%{box-shadow:0 0 #e11d4866}70%{box-shadow:0 0 0 6px #e11d4800}to{box-shadow:0 0 #e11d4800}}.timeline-item:before{content:"";background:var(--border-color);width:2px;position:absolute;top:18px;bottom:-6px;left:5px}.timeline-item:last-child:before{display:none}.timeline-content{border:1px solid var(--border-color);background:#fff;border-radius:8px;padding:16px 20px;box-shadow:0 1px 2px #00000005}.log-header{align-items:center;gap:12px;margin-bottom:8px;display:flex}.log-time{color:#64748b;font-size:13px}.log-rule-badge{color:#475569;background:#f1f5f9;border-radius:4px;padding:2px 8px;font-size:12px;font-weight:500}.log-unread-dot{background:#ef4444;border-radius:50%;width:8px;height:8px;display:inline-block}.log-title{color:var(--text-color);margin:0 0 16px;font-size:16px;font-weight:600}.log-detail-cards{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;flex-direction:column;gap:8px;padding:12px;display:flex}.post-card{border:1px solid var(--border-color);background:#fff;border-radius:4px;align-items:center;gap:12px;padding:8px 12px;text-decoration:none;transition:border-color .2s;display:flex}.post-card:hover{border-color:var(--primary-color)}.platform-tag{color:#4338ca;white-space:nowrap;background:#e0e7ff;border-radius:4px;padding:2px 6px;font-size:12px}.post-text{color:#334155;white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:13px;overflow:hidden}.score-tag{font-size:12px;font-weight:600}.score-tag.negative{color:#dc2626}.interaction-tag{color:#d97706;font-size:12px;font-weight:600}.stat-card{border:1px solid var(--border-color);background:#fff;border-radius:4px;justify-content:space-between;align-items:center;padding:8px 12px;font-size:13px;display:flex}.keyword-tag{color:#020617;font-weight:600}.load-more{text-align:center;margin-top:32px}.channel-checkbox-group{flex-wrap:wrap;gap:12px;margin-bottom:4px;display:flex}.channel-checkbox-item{cursor:pointer;border:1.5px solid var(--border-color);-webkit-user-select:none;user-select:none;background:#fff;border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-size:14px;font-weight:500;transition:border-color .2s,background .2s;display:flex}.channel-checkbox-item:has(input:checked){border-color:var(--primary-color);color:var(--primary-color);background:#eff6ff}.channel-checkbox-item.disabled{opacity:.7;cursor:not-allowed}.channel-checkbox-item input[type=checkbox]{accent-color:var(--primary-color);width:14px;height:14px}.channel-icon{font-size:16px}.channel-tag{background:var(--primary-color);color:#fff;border-radius:4px;margin-left:2px;padding:1px 5px;font-size:10px}.tag-input-wrapper{border:1px solid var(--border-color);cursor:text;background:#fff;border-radius:6px;flex-wrap:wrap;align-items:center;gap:6px;min-height:42px;padding:8px 12px;transition:border-color .2s,box-shadow .2s;display:flex}.tag-input-wrapper:focus-within{border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.tag-input-wrapper input{background:0 0;flex:1;min-width:160px;font-size:14px;box-shadow:none!important;border:none!important;outline:none!important;padding:0!important}.email-tag{color:#3730a3;background:#e0e7ff;border-radius:4px;align-items:center;gap:4px;padding:2px 8px;font-size:12px;font-weight:500;display:flex}.email-tag button{cursor:pointer;color:#3730a3;opacity:.7;background:0 0;border:none;padding:0 2px;font-size:14px;line-height:1}.email-tag button:hover{opacity:1}.rule-builder{border:1px solid var(--border-color);background:#f8fafc;border-radius:10px;margin-bottom:24px;padding:20px}.rule-builder-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:16px;display:flex}.rule-builder-label{color:#334155;font-size:14px;font-weight:600}.logic-switch{align-items:center;gap:6px;display:flex}.logic-label{color:#64748b;font-size:13px}.logic-btn{border:1.5px solid var(--border-color);color:#64748b;cursor:pointer;background:#fff;border-radius:6px;padding:4px 12px;font-size:13px;font-weight:500;transition:all .2s}.logic-btn.active{border-color:var(--primary-color);color:var(--primary-color);background:#eff6ff;font-weight:600}.logic-btn:hover:not(.active){border-color:#94a3b8}.condition-rows{flex-direction:column;gap:10px;margin-bottom:14px;display:flex}.condition-row{border:1px solid var(--border-color);background:#fff;border-radius:8px;align-items:center;gap:8px;padding:8px 10px;transition:border-color .2s,box-shadow .2s;display:flex}.condition-row:focus-within{border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb14}.condition-row-num{color:#4338ca;background:#e0e7ff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;min-width:22px;height:22px;font-size:11px;font-weight:700;display:flex}.condition-select{color:#334155;cursor:pointer;background:#f1f5f9;border:1px solid #0000;border-radius:6px;outline:none;padding:6px 10px;font-size:13px;transition:background .2s}.condition-select:focus{border-color:var(--primary-color);background:#e0e7ff}.field-select{min-width:130px}.op-select{min-width:100px}.value-select{flex:1;min-width:100px}.condition-input{background:#f1f5f9;border:1px solid #0000;border-radius:6px;outline:none;flex:1;min-width:80px;padding:6px 10px;font-size:13px;transition:background .2s,border-color .2s}.condition-input:focus{border-color:var(--primary-color);background:#fff;box-shadow:0 0 0 2px #2563eb14}.condition-remove-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:14px;transition:all .2s;display:flex}.condition-remove-btn:hover:not(:disabled){color:#dc2626;background:#fee2e2}.condition-remove-btn:disabled{opacity:.3;cursor:not-allowed}.add-condition-btn{color:#64748b;cursor:pointer;background:0 0;border:1.5px dashed #cbd5e1;border-radius:8px;justify-content:center;align-items:center;gap:6px;width:100%;padding:8px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.add-condition-btn:hover{border-color:var(--primary-color);color:var(--primary-color);background:#2563eb08}.rule-condition-desc{color:#475569;word-break:break-all;font-size:13px;line-height:1.6}.form-group input[type=url],.form-group input[type=email]{border:1px solid var(--border-color);border-radius:6px;outline:none;padding:10px 12px;font-size:14px}.form-group input[type=url]:focus,.form-group input[type=email]:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.notify-config-panel{border:1px solid var(--border-color);background:#f8fafc;border-radius:10px;margin-bottom:24px;padding:20px}.notify-config-panel h4{color:#334155;margin:0 0 16px;font-size:14px;font-weight:600}.notify-expand-section{border:1px solid var(--border-color);background:#fff;border-radius:8px;margin-top:16px;padding:16px;animation:.2s fadeIn}.notify-expand-label{color:#334155;margin-bottom:8px;font-size:13px;font-weight:600;display:block}.notify-full-input{border:1px solid var(--border-color);box-sizing:border-box;border-radius:6px;outline:none;width:100%;padding:10px 12px;font-size:14px;transition:border-color .2s,box-shadow .2s}.notify-full-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.notify-expand-section .tag-input-wrapper{margin-bottom:4px}.notify-expand-section .helper-text{margin-top:6px}.notify-expand-section input[type=tel]{background:0 0;flex:1;min-width:160px;font-size:14px;box-shadow:none!important;border:none!important;outline:none!important;padding:0!important}.keywords-page{flex-direction:column;height:100%;display:flex}.keywords-card{flex-direction:column;flex:1;display:flex}.keywords-header{border-bottom:1px solid var(--c-border);padding:0 32px}.tabs-container{gap:32px;display:flex}.tab-btn{font-family:var(--f-heading);color:var(--c-text-secondary);transition:color var(--dur) var(--ease);padding:24px 0 20px;font-size:1.05rem;font-weight:600;position:relative}.tab-btn:hover{color:var(--c-text)}.tab-btn.active{color:var(--c-primary)}.tab-indicator{background:var(--c-primary);border-radius:3px 3px 0 0;height:3px;position:absolute;bottom:0;left:0;right:0;box-shadow:0 -2px 10px #3470ff66}.keywords-content{flex-direction:column;flex:1;padding:32px;display:flex}.keywords-info{margin-bottom:24px}.keywords-info h3{color:var(--c-text);margin-bottom:8px;font-size:1.2rem;font-weight:700}.keywords-info p{color:var(--c-text-secondary);font-size:.95rem;line-height:1.6}.add-word-form{gap:16px;max-width:600px;margin-bottom:40px;display:flex}.add-word-form .input-wrapper{flex:1;position:relative}.add-word-form .input-wrapper svg{color:var(--c-text-muted);pointer-events:none;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.word-input{width:100%;height:48px;padding-left:44px}.add-word-form .btn{height:48px;padding:0 32px}.words-grid{flex-wrap:wrap;align-content:flex-start;gap:16px;display:flex}.word-node{background:var(--c-bg);border:1px solid var(--c-border);border-radius:var(--r-sm);transition:all var(--dur) var(--ease);align-items:center;gap:12px;padding:10px 16px;display:flex}.word-node:hover{border-color:var(--c-primary-light);box-shadow:var(--shadow-sm);background:#fff;transform:translateY(-2px)}.word-text{color:var(--c-text);font-size:.95rem;font-weight:600}.word-hash{color:var(--c-primary);opacity:.6;margin-right:4px}.word-badge{background:var(--c-primary-light);color:var(--c-primary);font-family:var(--f-display);border-radius:100px;padding:4px 8px;font-size:.75rem;font-weight:700}.del-btn{width:24px;height:24px;color:var(--c-text-muted);transition:all var(--dur) var(--ease);border-radius:50%;justify-content:center;align-items:center;margin-left:4px;display:flex}.del-btn:hover{color:var(--c-danger);background:#ffe8ec}.words-empty{text-align:center;width:100%;color:var(--c-text-muted);padding:60px 0;font-size:.95rem}.propagation-search{align-items:flex-end;gap:24px;padding:24px;display:flex}.search-group{flex:1;align-items:center;gap:16px;display:flex}.search-field{flex-direction:column;flex:1;gap:8px;display:flex}.search-field label{color:var(--c-text-secondary);font-size:.85rem;font-weight:600}.search-select,.search-input{border:1px solid var(--c-border);border-radius:var(--r-md);width:100%;height:44px;color:var(--c-text);background:var(--c-bg);padding:0 16px;font-family:inherit;font-size:.95rem;transition:all .2s}.search-divider{color:var(--c-text-secondary);opacity:.5;margin-top:24px;font-size:1.2rem;font-weight:700}.search-select:focus,.search-input:focus{border-color:var(--c-primary);outline:none;box-shadow:0 0 0 3px #3470ff1a}.analyze-btn{white-space:nowrap;height:44px;padding:0 32px;font-size:1rem}.empty-state{background:var(--c-surface);border-radius:var(--r-lg);border:1px dashed var(--c-border);color:var(--c-text-secondary);flex-direction:column;justify-content:center;align-items:center;padding:64px 0;display:flex}.empty-icon{opacity:.5;margin-bottom:16px;font-size:3rem}.origin-card{border-left:4px solid var(--c-primary);background:linear-gradient(90deg,#3470ff0d,#0000);padding:24px 32px;position:relative;overflow:hidden}.origin-card:after{content:"";pointer-events:none;background:radial-gradient(circle,#3470ff1a 0%,#0000 70%);border-radius:50%;width:150px;height:150px;position:absolute;top:-50px;right:-50px}.origin-card-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.origin-badge{background:var(--c-primary);color:#fff;border-radius:12px;padding:4px 10px;font-size:.75rem;font-weight:700}.origin-title{color:var(--c-text-secondary);font-size:.9rem;font-weight:500}.origin-meta{align-items:center;gap:12px;margin-bottom:12px;font-size:.85rem;display:flex}.origin-platform-badge{color:#fff;border-radius:4px;padding:2px 8px;font-size:.75rem;font-weight:600}.origin-platform-badge.mini{padding:2px 6px;font-size:.7rem}.origin-author{color:var(--c-text);font-weight:600}.origin-time{color:var(--c-text-secondary)}.origin-text{color:var(--c-text);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:16px;font-size:1.1rem;font-weight:600;line-height:1.6;display:-webkit-box;overflow:hidden}.origin-stats{align-items:center;gap:24px;display:flex}.origin-stat-item{color:var(--c-text-secondary);align-items:center;gap:6px;font-size:.95rem;font-weight:600;display:flex}.origin-link{color:var(--c-primary);margin-left:auto;font-size:.9rem;font-weight:600;text-decoration:none}.origin-link:hover{text-decoration:underline}.influencer-row{border-radius:var(--r-md);border-bottom:1px solid var(--c-bg);padding:16px;transition:background .2s}.influencer-row:hover{background:var(--c-bg)}.influencer-author{color:var(--c-text);font-weight:600}.influencer-stats{color:var(--c-text-secondary);align-items:center;gap:16px;margin:0 24px;font-size:.85rem;display:flex}.influencer-stat{align-items:center;gap:4px;min-width:48px;display:flex}.stat-icon-mini{opacity:.6}.influencer-link{width:32px;height:32px;color:var(--c-text-secondary);border-radius:50%;justify-content:center;align-items:center;margin-left:8px;transition:all .2s;display:flex}.influencer-link:hover{background:var(--c-surface);color:var(--c-primary)}@media (width<=768px){.origin-stats{flex-wrap:wrap;gap:12px}.influencer-stats{display:none}}.weibo-scraper{flex-direction:column;gap:16px;width:100%;display:flex}.scraper-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px 28px;box-shadow:0 1px 3px #0000000a}.scraper-card-header{align-items:center;gap:14px;margin-bottom:20px;display:flex}.scraper-icon{color:#fff;background:linear-gradient(135deg,#ff6a00,#ee0979);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.scraper-card-header h2{color:#0f172a;margin:0;font-size:18px;font-weight:700}.scraper-desc{color:#64748b;margin:2px 0 0;font-size:13px}.scraper-input-row{align-items:stretch;gap:10px;display:flex}.input-wrapper{flex:1}.keyword-input{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:8px;outline:none;width:100%;padding:12px 16px;font-size:15px;transition:border-color .2s,box-shadow .2s}.keyword-input:focus{background:#fff;border-color:#f97316;box-shadow:0 0 0 3px #f973161f}.keyword-input:disabled{opacity:.6;cursor:not-allowed}.btn-start,.btn-stop{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:6px;padding:0 22px;font-size:14px;font-weight:600;transition:background .2s,transform .1s;display:inline-flex}.btn-start{color:#fff;background:linear-gradient(135deg,#f97316,#ea580c)}.btn-start:hover:not(:disabled){background:linear-gradient(135deg,#ea580c,#c2410c);transform:translateY(-1px)}.btn-start:disabled{opacity:.4;cursor:not-allowed}.btn-stop{color:#dc2626;background:#fee2e2;border:1px solid #fecaca}.btn-stop:hover{background:#fecaca}.status-bar{color:#475569;background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;align-items:center;gap:12px;min-height:40px;padding:10px 16px;font-size:13px;font-weight:500;display:flex}.status-bar.scraping{color:#92400e;background:#fffbeb;border-color:#fed7aa}.status-bar.complete{color:#166534;background:#f0fdf4;border-color:#bbf7d0}.status-bar.error{color:#991b1b;background:#fef2f2;border-color:#fecaca}.status-left{flex:1;align-items:center;gap:8px;display:flex}.spinner{border:2px solid #f97316;border-top-color:#0000;border-radius:50%;width:14px;height:14px;animation:.8s linear infinite spin}.status-check{color:#fff;background:#22c55e;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:11px;font-weight:700;display:flex}.status-error-icon{color:#fff;background:#ef4444;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:11px;font-weight:700;display:flex}.progress-bar-wrapper{background:#fed7aa;border-radius:3px;flex:0 0 120px;height:6px;overflow:hidden}.progress-bar{background:linear-gradient(90deg,#f97316,#ea580c);border-radius:3px;height:100%;transition:width .5s}.status-count{font-variant-numeric:tabular-nums;color:#64748b;white-space:nowrap;font-size:12px}.error-banner{color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;justify-content:space-between;align-items:center;padding:10px 16px;font-size:13px;display:flex}.error-banner button{color:#991b1b;cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:16px}.result-table-wrapper{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000000a}.result-table{border-collapse:collapse;width:100%;font-size:13px}.result-table thead{background:#f8fafc;border-bottom:1px solid #e5e7eb}.result-table th{text-align:left;color:#475569;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;padding:12px 16px;font-size:12px;font-weight:600}.result-table td{vertical-align:top;color:#1e293b;border-bottom:1px solid #f1f5f9;padding:12px 16px}.result-table tbody tr:hover{background:#fffbf5}.result-table tbody tr.row-new{animation:.8s rowFlash}@keyframes rowFlash{0%{background:#fff7ed}to{background:0 0}}.author-name{color:#f97316;font-size:13px;font-weight:600}.post-content-cell{-webkit-line-clamp:3;color:#334155;-webkit-box-orient:vertical;max-width:500px;line-height:1.6;display:-webkit-box;overflow:hidden}.interaction-cell{color:#64748b;white-space:nowrap;flex-direction:column;gap:2px;font-size:12px;display:flex}.time-cell{color:#94a3b8;white-space:nowrap;font-size:12px}.link-btn{color:#f97316;background:#fff7ed;border:1px solid #fed7aa;border-radius:6px;align-items:center;padding:4px 10px;font-size:12px;font-weight:500;text-decoration:none;transition:background .2s;display:inline-flex}.link-btn:hover{color:#ea580c;background:#ffedd5}.empty-placeholder{text-align:center;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:80px 32px}.empty-icon-large{margin-bottom:12px;font-size:52px}.empty-placeholder h3{color:#334155;margin:0 0 6px;font-size:17px;font-weight:600}.empty-placeholder p{color:#94a3b8;margin:0;font-size:14px}:root{--c-primary:#3470ff;--c-primary-hover:#2a5fd9;--c-primary-light:#e8f0ff;--c-primary-glow:#3470ff2e;--c-accent:#00e5a0;--c-accent-warm:#ff6b35;--c-danger:#ff3b5c;--c-warning:#ffb819;--c-success:#00c48c;--c-bg:#f3f6fb;--c-bg-card:#fff;--c-bg-sidebar:#0c1b3a;--c-bg-sidebar-hover:#162d5a;--c-text:#1a2642;--c-text-secondary:#6b7a99;--c-text-muted:#9aacc2;--c-border:#e2e8f4;--c-divider:#edf1f7;--f-display:"Space Mono", monospace;--f-heading:"DM Sans", "Noto Sans SC", sans-serif;--f-body:"DM Sans", "Noto Sans SC", sans-serif;--r-sm:8px;--r-md:14px;--r-lg:20px;--r-xl:28px;--shadow-sm:0 1px 3px #1a26420f;--shadow-md:0 4px 20px #1a264214;--shadow-lg:0 12px 40px #1a26421f;--shadow-glow:0 0 40px var(--c-primary-glow);--ease:cubic-bezier(.4, 0, .2, 1);--dur:.25s}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--f-body);color:var(--c-text);background:var(--c-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:-1;background:radial-gradient(circle at 20% 30%,#3470ff0a 0%,#0000 50%),radial-gradient(circle at 80% 70%,#00e5a008 0%,#0000 50%);position:fixed;inset:0}a{color:var(--c-primary);transition:color var(--dur) var(--ease);text-decoration:none}a:hover{color:var(--c-primary-hover)}button{cursor:pointer;background:0 0;border:none;outline:none;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit;border:none;outline:none}.card{background:var(--c-bg-card);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);border:1px solid var(--c-border);transition:box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease)}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.btn{border-radius:var(--r-sm);transition:all var(--dur) var(--ease);white-space:nowrap;justify-content:center;align-items:center;gap:8px;padding:10px 24px;font-size:.875rem;font-weight:600;display:inline-flex}.btn-primary{background:var(--c-primary);color:#fff}.btn-primary:hover{background:var(--c-primary-hover);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.btn-ghost{color:var(--c-text-secondary);border:1px solid var(--c-border);background:0 0}.btn-ghost:hover{background:var(--c-primary-light);color:var(--c-primary);border-color:var(--c-primary)}.input{background:var(--c-bg);border:1.5px solid var(--c-border);border-radius:var(--r-sm);width:100%;color:var(--c-text);transition:border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);padding:12px 16px;font-size:.9rem}.input:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px var(--c-primary-glow);background:#fff}.input::placeholder{color:var(--c-text-muted)}.tag{letter-spacing:.02em;border-radius:100px;align-items:center;padding:4px 12px;font-size:.75rem;font-weight:600;display:inline-flex}.tag-blue{color:#3470ff;background:#e8f0ff}.tag-green{color:#00c48c;background:#e6faf3}.tag-red{color:#ff3b5c;background:#ffe8ec}.tag-orange{color:#ff6b35;background:#fff3e6}.tag-purple{color:#7c5cff;background:#f0e8ff}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--c-text-muted);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--c-text-secondary)}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:fadeSlideUp .5s var(--ease) both}.animate-delay-1{animation-delay:.1s}.animate-delay-2{animation-delay:.2s}.animate-delay-3{animation-delay:.3s}.animate-delay-4{animation-delay:.4s}.font-mono{font-family:var(--f-display);font-variant-numeric:tabular-nums}
