:root{--primary: #03045e;--secondary: #0077b6;--accent: #00b4d8;--light: #90e0ef;--lightbg: #caf0f8;--bg: #f0f4f8;--card: #ffffff;--text: #1a2332;--text2: #5a6475;--border: #e2e8f0;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--info: #3b82f6;--purple: #8b5cf6;--orange: #f97316;--sidebar-w: 230px;--header-h: 60px;--brand-primary: #03045e;--brand-primary-dark: #020338;--brand-primary-light: #e6e6ef;--brand-logo: url(/logo.svg);--brand-name: "GEO发布系统";--sidebar-bg: #03045e;--content-bg: #f0f4f8;--card-bg: #ffffff}:root{--primary-50: #eef2ff;--primary-100: #dbeafe;--primary-200: #bfdbfe;--primary-300: #93c5fd;--primary-400: #60a5fa;--primary-600: #02034a;--primary-700: #01023a;--primary-800: #01022d;--primary-900: #01011c;--secondary-50: #e0f2fe;--secondary-100: #bae6fd;--secondary-200: #7dd3fc;--secondary-300: #38bdf8;--secondary-500: #0077b6;--secondary-600: #0369a1;--secondary-700: #075985;--secondary-800: #0c4a6e;--secondary-900: #082f49;--accent-50: #ecfeff;--accent-100: #cffafe;--accent-200: #a5f3fc;--accent-600: #0891b2;--accent-700: #0e7490;--accent-800: #155e75;--accent-900: #164e63;--success-50: #ecfdf5;--success-100: #d1fae5;--success-200: #a7f3d0;--success-600: #059669;--success-700: #047857;--success-800: #065f46;--success-900: #064e3b;--warning-50: #fffbeb;--warning-100: #fef3c7;--warning-200: #fde68a;--warning-600: #d97706;--warning-700: #b45309;--warning-800: #92400e;--warning-900: #78350f;--danger-50: #fef2f2;--danger-100: #fee2e2;--danger-200: #fecaca;--danger-600: #dc2626;--danger-700: #b91c1c;--danger-800: #991b1b;--danger-900: #7f1d1d;--info-50: #eff6ff;--info-100: #dbeafe;--info-200: #bfdbfe;--info-600: #2563eb;--info-700: #1d4ed8;--info-800: #1e40af;--info-900: #1e3a8a;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--primary: #03045e;--secondary: #0077b6;--accent: #00b4d8;--light: #90e0ef;--lightbg: #caf0f8;--bg: #f0f4f8;--card: #ffffff;--text: #1a2332;--text2: #5a6475;--border: #e2e8f0;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--info: #3b82f6;--sidebar-w: 230px;--header-h: 60px;--radius-xs: 4px;--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--radius-xl: 24px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .16);--transition: all .2s ease;--transition-fast: all .15s ease;--transition-slow: all .3s ease;--text-xs: 11px;--text-sm: 12px;--text-base: 13px;--text-md: 14px;--text-lg: 16px;--text-xl: 18px;--text-2xl: 20px;--text-3xl: 24px;--text-4xl: 32px;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.6;--vi-blue: #0077b6;--vi-green: #10b981;--vi-purple: #8b5cf6;--vi-orange: #f97316;--vi-cyan: #00b4d8;--vi-red: #ef4444;--vi-indigo: #4f46e5;--vi-pink: #db2777;--border-card: #d0d8e4}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:Microsoft YaHei,PingFang SC,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.top-header{height:var(--header-h);background:var(--primary);display:flex;align-items:center;padding:0 20px;flex-shrink:0;gap:16px;z-index:100;box-shadow:0 2px 8px #0003}.top-header .logo{display:flex;align-items:center;gap:10px;color:#fff;font-size:var(--text-2xl);font-weight:700;letter-spacing:.5px;white-space:nowrap}.top-header .logo .badge{background:var(--accent);color:#fff;font-size:var(--text-xs);padding:2px 7px;border-radius:10px;font-weight:600}.top-header .header-nav{display:flex;gap:4px;flex:1;overflow-x:auto;padding:0 8px}.top-header .header-nav button{background:none;border:none;color:#ffffffb3;padding:6px 14px;border-radius:6px;cursor:pointer;font-size:var(--text-base);white-space:nowrap;transition:var(--transition)}.top-header .header-nav button:hover,.top-header .header-nav button.active{background:#ffffff26;color:#fff}.top-header .header-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.balance-chip{background:#00b4d840;color:var(--light);font-size:var(--text-sm);padding:4px 12px;border-radius:20px;border:1px solid rgba(0,180,216,.4);cursor:pointer;display:flex;align-items:center;gap:6px;transition:var(--transition)}.balance-chip:hover{background:#00b4d866}.avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--secondary));display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--text-base);font-weight:700;cursor:pointer;transition:var(--transition)}.avatar:hover{transform:scale(1.05);box-shadow:0 2px 8px #00b4d866}.notif-btn{background:none;border:none;color:#ffffffb3;cursor:pointer;font-size:var(--text-lg);position:relative;padding:4px;transition:var(--transition)}.notif-btn:hover{color:#fff}.notif-btn .dot{position:absolute;top:2px;right:2px;width:8px;height:8px;background:var(--danger);border-radius:50%;border:2px solid var(--primary)}.layout{display:flex;flex:1;overflow:hidden}.sidebar{width:var(--sidebar-w);background:var(--card);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}.sidebar-section{padding:6px 0}.sidebar-section-title{font-size:var(--text-xs);color:var(--text2);padding:4px 16px;text-transform:uppercase;letter-spacing:1px;font-weight:600}.sidebar-item{display:flex;align-items:center;gap:10px;padding:9px 16px;cursor:pointer;font-size:var(--text-base);color:var(--text2);border-left:3px solid transparent;transition:var(--transition);position:relative}.sidebar-item:hover{background:var(--gray-50);color:var(--text);border-left-color:var(--light)}.sidebar-item.active{background:var(--accent-50);color:var(--secondary);border-left-color:var(--secondary);font-weight:600}.sidebar-item .icon{font-size:var(--text-md);width:18px;text-align:center;flex-shrink:0}.sidebar-divider{height:1px;background:var(--border);margin:4px 12px}.main{flex:1;overflow-y:auto;display:flex;flex-direction:column}.page{display:none;flex:1;flex-direction:column;padding:24px;gap:20px}.page.active{display:flex;animation:fadeIn .25s ease}.app-content{animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.page-title-bar{margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border)}.page-title-bar h1{font-size:var(--text-3xl);font-weight:700;color:var(--primary);display:flex;align-items:center;gap:8px;line-height:1.4}.page-title-bar h1 .emoji{font-size:var(--text-2xl)}.page-title-bar .sub{font-size:var(--text-base);color:var(--text2);font-weight:400;margin-left:4px}.card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border-card);box-shadow:var(--shadow-sm);transition:var(--transition);position:relative}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-header{padding:13px 20px 13px 24px;border-bottom:2px solid var(--border);display:flex;align-items:center;gap:10px;position:relative;background:var(--gray-50)}.card-header:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:12px 0 0;background:var(--border-card)}.card-header h3{font-size:var(--text-md);font-weight:700;color:var(--text);flex:1}.card-header .header-actions{display:flex;gap:8px;flex-shrink:0}.card-body{padding:20px}.card-vi-blue .card-header:before{background:var(--vi-blue)}.card-vi-blue .card-header h3{color:var(--vi-blue)}.card-vi-green .card-header:before{background:var(--vi-green)}.card-vi-green .card-header h3{color:var(--vi-green)}.card-vi-purple .card-header:before{background:var(--vi-purple)}.card-vi-purple .card-header h3{color:var(--vi-purple)}.card-vi-orange .card-header:before{background:var(--vi-orange)}.card-vi-orange .card-header h3{color:var(--vi-orange)}.card-vi-cyan .card-header:before{background:var(--vi-cyan)}.card-vi-cyan .card-header h3{color:var(--vi-cyan)}.card-vi-red .card-header:before{background:var(--vi-red)}.card-vi-red .card-header h3{color:var(--vi-red)}.card-vi-indigo .card-header:before{background:var(--vi-indigo)}.card-vi-indigo .card-header h3{color:var(--vi-indigo)}.card-vi-blue{border-top:3px solid var(--vi-blue)}.card-vi-green{border-top:3px solid var(--vi-green)}.card-vi-purple{border-top:3px solid var(--vi-purple)}.card-vi-orange{border-top:3px solid var(--vi-orange)}.card-vi-cyan{border-top:3px solid var(--vi-cyan)}.card-vi-red{border-top:3px solid var(--vi-red)}.card-vi-indigo{border-top:3px solid var(--vi-indigo)}.card-header .vi-icon{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:var(--text-md);flex-shrink:0}.card-vi-blue .card-header .vi-icon{background:var(--secondary-50)}.card-vi-green .card-header .vi-icon{background:var(--success-100)}.card-vi-purple .card-header .vi-icon{background:#ede9fe}.card-vi-orange .card-header .vi-icon{background:#ffedd5}.card-vi-cyan .card-header .vi-icon{background:var(--accent-100)}.card-vi-red .card-header .vi-icon{background:var(--danger-100)}.card-vi-indigo .card-header .vi-icon{background:#e0e7ff}.card-flat{box-shadow:none}.card-flat:hover{box-shadow:var(--shadow-sm)}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}.mb-24{margin-bottom:24px}.mb-28{margin-bottom:28px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mt-24{margin-top:24px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.gap-24{gap:24px}.p-16{padding:16px}.p-20{padding:20px}.p-24{padding:24px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}.grid-2-1{display:grid;grid-template-columns:2fr 1fr;gap:20px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.page-section{margin-bottom:28px}.page-section:last-child{margin-bottom:0}.section-title{font-size:var(--text-md);font-weight:700;color:var(--text);margin-bottom:16px;padding:8px 14px;background:var(--bg);border-radius:var(--radius-sm);border-left:4px solid var(--secondary);line-height:1.5;display:flex;align-items:center;gap:8px}.section-title .st-icon{font-size:var(--text-lg);flex-shrink:0}.section-title.section-blue{border-left-color:var(--vi-blue);background:var(--info-50)}.section-title.section-green{border-left-color:var(--vi-green);background:var(--success-50)}.section-title.section-purple{border-left-color:var(--vi-purple);background:#f5f3ff}.section-title.section-orange{border-left-color:var(--vi-orange);background:var(--warning-50)}.section-title.section-cyan{border-left-color:var(--vi-cyan);background:var(--accent-50)}.section-title.section-red{border-left-color:var(--vi-red);background:var(--danger-50)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.stat-card{background:var(--card);border:1px solid var(--border);border-top:3px solid var(--border);border-left:4px solid var(--border);border-radius:var(--radius);padding:18px 20px 18px 16px;display:flex;flex-direction:column;gap:8px;transition:var(--transition);box-shadow:var(--shadow-sm);cursor:pointer;position:relative}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.stat-card .label{font-size:var(--text-sm);color:var(--text2)}.stat-card .value{font-size:var(--text-4xl);font-weight:700;color:var(--primary);line-height:1}.stat-card .change{font-size:var(--text-xs);display:flex;align-items:center;gap:4px}.stat-card .change.up{color:var(--success)}.stat-card .change.down{color:var(--danger)}.stat-card .change.neutral{color:var(--text2)}.stat-card .icon-wrap{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:var(--text-xl);margin-bottom:4px}.stat-card.accent{border-top:3px solid var(--accent);border-left:4px solid var(--accent)}.stat-card.secondary{border-top:3px solid var(--secondary);border-left:4px solid var(--secondary)}.stat-card.success{border-top:3px solid var(--success);border-left:4px solid var(--success)}.stat-card.warning{border-top:3px solid var(--warning);border-left:4px solid var(--warning)}.stat-card.danger{border-top:3px solid var(--danger);border-left:4px solid var(--danger)}.stat-card.purple{border-top:3px solid var(--vi-purple);border-left:4px solid var(--vi-purple)}.stat-card.orange{border-top:3px solid var(--vi-orange);border-left:4px solid var(--vi-orange)}.icon-bg-blue{background:var(--secondary-50);color:var(--secondary)}.icon-bg-green{background:var(--success-100);color:var(--success)}.icon-bg-purple{background:#ede9fe;color:var(--vi-purple)}.icon-bg-orange{background:var(--warning-100);color:var(--warning)}.icon-bg-red{background:var(--danger-100);color:var(--danger)}.icon-bg-cyan{background:var(--accent-100);color:var(--accent-800)}.icon-bg-indigo{background:#e0e7ff;color:var(--vi-indigo)}.icon-bg-pink{background:#fce7f3;color:var(--vi-pink)}.btn{padding:8px 18px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-base);font-weight:600;transition:var(--transition);display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.btn-primary{background:var(--secondary);color:#fff}.btn-primary:hover{background:var(--primary);box-shadow:0 2px 8px #03045e4d}.btn-accent{background:var(--accent);color:#fff}.btn-accent:hover{background:var(--secondary)}.btn-ghost{background:none;border:1px solid var(--border);color:var(--text2)}.btn-ghost:hover{border-color:var(--secondary);color:var(--secondary);background:var(--accent-50)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:var(--danger-600)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:var(--success-600)}.btn:active{transform:scale(.95);transition:transform .15s ease}.btn-gradient{background:linear-gradient(135deg,var(--secondary),var(--accent));color:#fff;box-shadow:0 2px 8px #0077b64d}.btn-gradient:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 12px #0077b666}.btn-sm{padding:5px 12px;font-size:var(--text-sm)}.tag{display:inline-flex;align-items:center;padding:2px 10px;border-radius:20px;font-size:var(--text-xs);font-weight:600}.tag-blue{background:var(--info-100);color:var(--info-700)}.tag-green{background:var(--success-100);color:var(--success-800)}.tag-orange{background:var(--warning-100);color:var(--warning-800)}.tag-red{background:var(--danger-100);color:var(--danger-700)}.tag-gray{background:var(--gray-100);color:var(--gray-600)}.tag-purple{background:#ede9fe;color:#6d28d9}.tag-cyan{background:var(--accent-100);color:var(--accent-800)}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:var(--text-base)}thead th{padding:10px 14px;text-align:left;font-size:var(--text-xs);color:var(--text2);font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--secondary);background:var(--info-50)}tbody td{padding:12px 14px;border-bottom:1px solid var(--border);vertical-align:middle}tbody tr:hover td{background:var(--gray-50)}tbody tr:last-child td{border-bottom:none}.form-row{display:flex;gap:16px;flex-wrap:wrap;align-items:flex-end}.form-group{display:flex;flex-direction:column;gap:6px;flex:1;min-width:140px}.form-group label{font-size:var(--text-sm);color:var(--text2);font-weight:600}.form-control{padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--text-base);outline:none;background:var(--card);transition:border .15s,box-shadow .15s;color:var(--text);width:100%}.form-control:focus{border-color:var(--accent);box-shadow:0 0 0 3px #00b4d81f}.form-control::-moz-placeholder{color:var(--gray-400)}.form-control::placeholder{color:var(--gray-400)}textarea.form-control{resize:vertical;min-height:80px;font-family:inherit}select.form-control{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%235a6475' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;cursor:pointer}select.form-control:hover{border-color:var(--gray-300)}.tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:20px}.tab-btn{padding:10px 20px;background:none;border:none;border-bottom:2px solid transparent;font-size:var(--text-base);color:var(--text2);cursor:pointer;transition:var(--transition);margin-bottom:-2px;font-weight:500;border-radius:6px 6px 0 0}.tab-btn:hover{color:var(--secondary);background:var(--info-50)}.tab-btn.active{color:var(--secondary);border-bottom-color:var(--secondary);font-weight:700;background:var(--info-50)}.tab-content{display:none}.tab-content.active{display:block;animation:fadeIn .2s ease}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:12px;color:var(--text2)}.empty-state .icon{font-size:48px;opacity:.4}.empty-state p{font-size:var(--text-base)}.progress-bar{height:6px;background:var(--gray-200);border-radius:3px;overflow:hidden}.progress-fill{height:100%;border-radius:3px;transition:width .3s}.progress-fill.blue{background:var(--secondary)}.progress-fill.green{background:var(--success)}.progress-fill.orange{background:var(--warning)}.modal-overlay{display:none;position:fixed;inset:0;background:#00000073;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;align-items:center;justify-content:center}.modal-overlay.open{display:flex}.modal{background:var(--card);border-radius:var(--radius-xl);width:600px;max-width:95vw;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:fadeIn .2s ease;position:relative;border-top:4px solid var(--secondary)}.modal-header{padding:20px 24px 16px;border-bottom:2px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--gray-50)}.modal-header h3{font-size:var(--text-lg);font-weight:700;color:var(--primary);display:flex;align-items:center;gap:8px}.modal-close{background:none;border:none;font-size:var(--text-2xl);cursor:pointer;color:var(--text2);padding:6px;border-radius:8px;transition:var(--transition);width:32px;height:32px;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--danger-50);color:var(--danger)}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:2px solid var(--border);display:flex;justify-content:flex-end;gap:10px;background:var(--gray-50)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.media-type-nav{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.media-type-pill{padding:5px 14px;border-radius:20px;font-size:var(--text-sm);font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--card);color:var(--text2);transition:var(--transition)}.media-type-pill:hover,.media-type-pill.active{background:var(--secondary);color:#fff;border-color:var(--secondary)}.score-ring{width:120px;height:120px;position:relative;display:flex;align-items:center;justify-content:center}.score-ring svg{position:absolute;transform:rotate(-90deg)}.score-ring .score-val{font-size:var(--text-4xl);font-weight:700;color:var(--primary);z-index:1}.score-ring .score-sub{font-size:var(--text-xs);color:var(--text2);z-index:1}.kw-level{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-xs);font-size:var(--text-xs);font-weight:700}.kw-l1{background:var(--danger-100);color:var(--danger-700)}.kw-l2{background:var(--warning-100);color:var(--warning-700)}.kw-l3{background:var(--success-100);color:var(--success-800)}.kw-l4{background:var(--info-100);color:var(--info-700)}.status-dot{width:7px;height:7px;border-radius:50%;display:inline-block;margin-right:5px}.status-dot.green{background:var(--success)}.status-dot.orange{background:var(--warning)}.status-dot.red{background:var(--danger)}.status-dot.blue{background:var(--info)}.status-dot.gray{background:var(--gray-400)}.pipeline{display:flex;align-items:center;gap:0;overflow-x:auto;padding:4px 0}.pipeline-step{display:flex;align-items:center;flex-shrink:0;background:var(--gray-100);border-radius:var(--radius-xs);padding:6px 14px;font-size:var(--text-sm);color:var(--text2);font-weight:600;gap:6px}.pipeline-step.done{background:var(--success-100);color:var(--success-800)}.pipeline-step.active{background:var(--info-100);color:var(--info-700)}.pipeline-step.error{background:var(--danger-100);color:var(--danger-700)}.pipeline-arrow{color:var(--gray-300);font-size:var(--text-md);padding:0 4px;flex-shrink:0}.api-status-bar{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--success-50);border:1px solid var(--success-200);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--success-800)}.api-status-bar.error{background:var(--danger-50);border-color:var(--danger-200);color:var(--danger-700)}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.quick-action-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;text-align:center;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-sm)}.quick-action-card:hover{border-color:var(--accent);box-shadow:0 4px 12px #00b4d826;transform:translateY(-2px)}.quick-action-card .icon{font-size:var(--text-4xl);margin-bottom:8px}.quick-action-card .title{font-size:var(--text-base);font-weight:600;color:var(--text)}.quick-action-card .desc{font-size:var(--text-xs);color:var(--text2);margin-top:2px}.todo-list{display:flex;flex-direction:column;gap:8px}.todo-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--gray-50);border-radius:var(--radius-sm);border:1px solid var(--border);transition:var(--transition)}.todo-item:hover{background:var(--bg)}.todo-item .todo-check{width:18px;height:18px;border-radius:50%;border:2px solid var(--border);cursor:pointer;flex-shrink:0;transition:var(--transition)}.todo-item .todo-check:hover{border-color:var(--success)}.todo-item .todo-check.done{background:var(--success);border-color:var(--success)}.todo-item .todo-text{flex:1;font-size:var(--text-base)}.todo-item .todo-text.done{text-decoration:line-through;color:var(--text2)}.todo-item .todo-tag{font-size:var(--text-xs);padding:2px 8px;border-radius:10px;background:var(--info-100);color:var(--info-700)}.timeline{position:relative;padding-left:20px}.timeline:before{content:"";position:absolute;left:5px;top:0;bottom:0;width:2px;background:var(--border)}.timeline-item{position:relative;padding-bottom:16px}.timeline-item:before{content:"";position:absolute;left:-17px;top:4px;width:10px;height:10px;border-radius:50%;background:var(--accent);border:2px solid var(--card)}.timeline-item .time{font-size:var(--text-xs);color:var(--text2)}.timeline-item .text{font-size:var(--text-base);margin-top:2px}.model-selector{display:flex;gap:8px;flex-wrap:wrap}.model-chip{padding:6px 14px;border-radius:20px;font-size:var(--text-sm);cursor:pointer;border:1px solid var(--border);background:var(--card);transition:var(--transition);display:flex;align-items:center;gap:6px}.model-chip:hover{border-color:var(--accent);background:var(--accent-50)}.model-chip.active{background:var(--secondary);color:#fff;border-color:var(--secondary)}.model-chip .dot{width:6px;height:6px;border-radius:50%;background:var(--success)}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.template-card{padding:12px;border:1px solid var(--border);border-radius:10px;text-align:center;cursor:pointer;transition:var(--transition);background:var(--card)}.template-card:hover{border-color:var(--accent);background:var(--accent-50)}.template-card.active{border-color:var(--secondary);background:var(--accent-50)}.template-card .icon{font-size:var(--text-3xl);margin-bottom:6px}.template-card .name{font-size:var(--text-sm);font-weight:600}.media-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.media-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;transition:var(--transition);box-shadow:var(--shadow-sm)}.media-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.media-card .mc-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.media-card .mc-icon{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--accent-50);display:flex;align-items:center;justify-content:center;font-size:var(--text-2xl)}.media-card .mc-name{font-size:var(--text-md);font-weight:600;flex:1}.media-card .mc-meta{display:flex;gap:12px;font-size:var(--text-sm);color:var(--text2);margin-bottom:10px}.media-card .mc-footer{display:flex;align-items:center;justify-content:space-between}.media-card .mc-price{font-size:var(--text-lg);font-weight:700;color:var(--danger)}.quota-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}.quota-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow-sm)}.quota-card .q-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:var(--text-2xl)}.quota-card .q-info{flex:1}.quota-card .q-label{font-size:var(--text-sm);color:var(--text2)}.quota-card .q-value{font-size:var(--text-xl);font-weight:700;margin-top:2px}.quota-card .q-bar{margin-top:6px}.ai-tool-box{background:linear-gradient(135deg,var(--accent-50),var(--secondary-50));border:2px dashed var(--light);border-radius:16px;padding:40px;text-align:center}.cart-float{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--secondary),var(--accent));color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--text-2xl);cursor:pointer;box-shadow:0 4px 16px #0077b666;z-index:500;transition:var(--transition)}.cart-float:hover{transform:scale(1.1);box-shadow:0 6px 20px #0077b680}.cart-float .cart-count{position:absolute;top:-4px;right:-4px;width:22px;height:22px;background:var(--danger);color:#fff;border-radius:50%;font-size:var(--text-xs);font-weight:700;display:flex;align-items:center;justify-content:center}.toast-container{position:fixed;top:70px;right:20px;z-index:2000;display:flex;flex-direction:column;gap:8px}.toast{background:var(--card);border-radius:10px;padding:12px 18px;box-shadow:0 4px 20px #00000026;display:flex;align-items:center;gap:10px;font-size:var(--text-base);border-left:4px solid var(--success);animation:slideIn .3s ease}.toast.error{border-left-color:var(--danger)}.toast.warning{border-left-color:var(--warning)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.kw-matrix{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.kw-group{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:14px;box-shadow:var(--shadow-sm)}.kw-group h4{font-size:var(--text-base);margin-bottom:10px;display:flex;align-items:center;gap:6px}.kw-group .kw-tags{display:flex;flex-wrap:wrap;gap:6px}.kw-group .kw-tag{padding:3px 10px;border-radius:6px;font-size:var(--text-sm);background:var(--gray-100);color:var(--gray-600);cursor:pointer;transition:var(--transition)}.kw-group .kw-tag:hover{background:var(--secondary);color:#fff}.combo-area{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-bottom:16px}.combo-box{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px}.combo-box label{font-size:var(--text-xs);color:var(--text2);margin-bottom:6px;display:block}.combo-box textarea{width:100%;border:none;outline:none;font-size:var(--text-sm);resize:vertical;min-height:60px;font-family:inherit;background:transparent}.combo-options{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.combo-opt{padding:5px 12px;border-radius:6px;font-size:var(--text-sm);cursor:pointer;border:1px solid var(--border);background:var(--card);transition:var(--transition)}.combo-opt:hover{border-color:var(--accent)}.combo-opt.active{background:var(--secondary);color:#fff;border-color:var(--secondary)}.auth-steps{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:24px}.auth-step{display:flex;align-items:center;gap:8px;font-size:var(--text-base);color:var(--text2)}.auth-step .num{width:28px;height:28px;border-radius:50%;background:var(--border);display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:700}.auth-step.active{color:var(--secondary);font-weight:600}.auth-step.active .num{background:var(--secondary);color:#fff}.auth-step.done{color:var(--success)}.auth-step.done .num{background:var(--success);color:#fff}@media(max-width:900px){.sidebar{display:none}.media-card-grid{grid-template-columns:1fr}.combo-area{grid-template-columns:repeat(3,1fr)}.grid-2,.grid-2-1,.grid-3{grid-template-columns:1fr}}.admin-only{display:none}body.admin-mode .admin-only{display:block}.avatar-menu{position:absolute;top:50px;right:0;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 30px #00000026;padding:12px;min-width:200px;z-index:200;display:none;animation:fadeIn .15s ease}.avatar-menu.open{display:block}.avatar-menu .menu-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-base);color:var(--text);transition:background .15s}.avatar-menu .menu-item:hover{background:var(--gray-50)}.avatar-menu .menu-item .role-badge{font-size:var(--text-xs);padding:2px 8px;border-radius:10px;margin-left:auto}.avatar-menu .menu-item .role-badge.admin{background:var(--danger-100);color:var(--danger-700)}.avatar-menu .menu-item .role-badge.user{background:var(--info-100);color:var(--info-700)}.avatar-menu .divider{height:1px;background:var(--border);margin:8px 0}.asset-map{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}.asset-map-item{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:14px;text-align:center;transition:var(--transition);box-shadow:var(--shadow-sm)}.asset-map-item:hover{box-shadow:var(--shadow-md)}.asset-map-item .platform-icon{font-size:var(--text-4xl);margin-bottom:6px}.asset-map-item .platform-name{font-size:var(--text-md);font-weight:600;margin-bottom:4px}.asset-map-item .platform-status{font-size:var(--text-xs)}.asset-map-item .platform-status.active{color:var(--success)}.asset-map-item .platform-status.inactive{color:var(--text2)}.platform-ind-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;align-items:center;gap:16px;transition:var(--transition);box-shadow:var(--shadow-sm)}.platform-ind-card:hover{box-shadow:var(--shadow-md)}.platform-ind-card .pb-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:var(--text-2xl);flex-shrink:0}.platform-ind-card .pb-info{flex:1}.platform-ind-card .pb-name{font-size:var(--text-md);font-weight:600}.platform-ind-card .pb-status{font-size:var(--text-sm);color:var(--text2);margin-top:2px}.platform-ind-card .pb-fans{font-size:var(--text-lg);font-weight:700;color:var(--primary)}.platform-ind-card .pb-action{flex-shrink:0}.level-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:24px;text-align:center;transition:var(--transition);position:relative;overflow:hidden}.level-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.level-card .lc-icon{font-size:var(--text-4xl);margin-bottom:10px}.level-card .lc-name{font-size:var(--text-lg);font-weight:700;color:var(--primary);margin-bottom:4px}.level-card .lc-discount{font-size:var(--text-3xl);font-weight:700;color:var(--accent);margin-bottom:4px}.level-card .lc-desc{font-size:var(--text-sm);color:var(--text2)}.level-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px}.level-card.gold:before{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.level-card.silver:before{background:linear-gradient(90deg,#94a3b8,#cbd5e1)}.level-card.platinum:before{background:linear-gradient(90deg,#8b5cf6,#a78bfa)}.level-card.vip:before{background:linear-gradient(90deg,var(--secondary),var(--accent))}.level-card.normal:before{background:var(--border)}.comm-tier{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;text-align:center}.comm-tier .tier-label{font-size:var(--text-base);font-weight:600;color:var(--text2);margin-bottom:8px}.comm-tier .tier-rate{font-size:var(--text-4xl);font-weight:700;color:var(--primary)}.comm-tier .tier-desc{font-size:var(--text-xs);color:var(--text2);margin-top:4px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-grid .cal-header{font-size:var(--text-xs);font-weight:600;color:var(--text2);text-align:center;padding:6px}.calendar-grid .cal-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:var(--text-sm);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);border:1px solid transparent}.calendar-grid .cal-day:hover{background:var(--gray-50);border-color:var(--border)}.calendar-grid .cal-day.today{background:var(--accent-50);border-color:var(--secondary);font-weight:600}.calendar-grid .cal-day.has-event:after{content:"";width:4px;height:4px;border-radius:50%;background:var(--accent);margin-top:2px}.calendar-grid .cal-day.empty{cursor:default}.faq-builder{display:flex;flex-direction:column;gap:12px}.faq-item{display:flex;gap:12px;align-items:flex-start;padding:14px;background:var(--gray-50);border-radius:10px;border:1px solid var(--border)}.faq-item .faq-q,.faq-item .faq-a{flex:1}.faq-item .faq-num{width:28px;height:28px;border-radius:50%;background:var(--secondary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:700;flex-shrink:0}.faq-item input{width:100%}.tag-cloud{display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:center}.tag-cloud .tc-tag{padding:4px 12px;border-radius:20px;font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:var(--transition)}.tag-cloud .tc-tag:hover{transform:scale(1.05)}.tag-cloud .tc-tag.s1{font-size:var(--text-xs);background:var(--gray-100);color:var(--gray-600)}.tag-cloud .tc-tag.s2{font-size:var(--text-sm);background:var(--info-100);color:var(--info-700)}.tag-cloud .tc-tag.s3{font-size:var(--text-md);background:var(--vi-purple);color:#fff}.tag-cloud .tc-tag.s4{font-size:var(--text-lg);background:var(--warning-100);color:var(--warning-800)}.tag-cloud .tc-tag.s5{font-size:var(--text-xl);background:var(--danger-100);color:var(--danger-800)}.knowledge-graph{position:relative;min-height:300px;background:var(--gray-50);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden}.kg-node{position:absolute;padding:8px 16px;border-radius:20px;font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:var(--transition);white-space:nowrap}.kg-node:hover{transform:scale(1.08);z-index:2;box-shadow:var(--shadow-md)}.kg-node.center{background:var(--secondary);color:#fff;font-size:var(--text-md);padding:10px 20px}.kg-node.l1{background:var(--info-100);color:var(--info-700)}.kg-node.l2{background:#ede9fe;color:#6d28d9}.radar-wrap{display:flex;align-items:center;justify-content:center;padding:20px}.hierarchy-tree{padding:20px}.hierarchy-tree .ht-node{display:flex;align-items:center;gap:10px;padding:8px 0 8px 24px;border-left:2px solid var(--border);margin-left:12px;position:relative}.hierarchy-tree .ht-node:before{content:"";position:absolute;left:-2px;top:50%;width:16px;height:2px;background:var(--border)}.hierarchy-tree .ht-node .ht-name{font-size:var(--text-base);font-weight:600}.hierarchy-tree .ht-node .ht-badge{font-size:var(--text-xs);padding:2px 8px;border-radius:10px}.hierarchy-tree .ht-root{font-size:var(--text-md);font-weight:700;color:var(--primary);padding:8px 0;margin-left:0;border-left:none}.hierarchy-tree .ht-root:before{display:none}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.shrink{flex-shrink:1}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.break-all{word-break:break-all}.border{border-width:1px}.uppercase{text-transform:uppercase}.italic{font-style:italic}.underline{text-decoration-line:underline}.overline{text-decoration-line:overline}.outline{outline-style:solid}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f0f4f8}#root{min-height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#c4c4c4;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#999}.admin-only-menu,.admin-only-block{display:none!important}body.admin-mode .admin-only-menu{display:flex!important}body.admin-mode .admin-only-block{display:block!important}
