:root{--color-bg: #FAFAF9;--color-bg-secondary: #F5F5F4;--color-surface: #FFFFFF;--color-surface-hover: #FAFAF9;--color-text: #1C1917;--color-text-secondary: #44403C;--color-text-muted: #A8A29E;--color-border: #E7E5E4;--color-border-dark: #D6D3D1;--color-primary: #1C1917;--color-primary-hover: #292524;--color-accent: #57534E;--color-success: #22C55E;--color-warning: #F59E0B;--color-error: #EF4444;--color-info: #3B82F6;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--text-xs: 12px;--text-sm: 14px;--text-base: 16px;--text-lg: 18px;--text-xl: 20px;--text-2xl: 24px;--text-3xl: 30px}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%}a{text-decoration:none;color:inherit}button{border:none;background:none;cursor:pointer;font-family:inherit}input,textarea{font-family:inherit}ul,ol{list-style:none}.container{max-width:1200px;margin:0 auto;padding:0 var(--space-md)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);font-size:var(--text-base);font-weight:500;transition:all .2s ease}.btn-primary{background-color:var(--color-primary);color:var(--color-bg)}.btn-primary:hover{background-color:var(--color-primary-hover)}.btn-secondary{background-color:var(--color-bg-secondary);color:var(--color-text)}.btn-secondary:hover{background-color:var(--color-border)}.btn-outline{background-color:transparent;border:1px solid var(--color-border);color:var(--color-text)}.btn-outline:hover{border-color:var(--color-border-dark);background-color:var(--color-bg-secondary)}.btn-lg{padding:var(--space-md) var(--space-xl);font-size:var(--text-lg)}.btn-sm{padding:var(--space-xs) var(--space-md);font-size:var(--text-sm)}.input{width:100%;padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-base);background-color:var(--color-surface);color:var(--color-text);transition:border-color .2s ease}.input:focus{outline:none;border-color:var(--color-primary)}.input::placeholder{color:var(--color-text-muted)}.textarea{resize:vertical;min-height:120px}.card{background-color:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm)}.card-hover{transition:box-shadow .2s ease}.card-hover:hover{box-shadow:var(--shadow-md)}.divider{height:1px;background-color:var(--color-border);margin:var(--space-lg) 0}.badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:500}.badge-primary{background-color:var(--color-primary);color:var(--color-bg)}.badge-success{background-color:var(--color-success);color:#fff}.badge-warning{background-color:var(--color-warning);color:#fff}.badge-error{background-color:var(--color-error);color:#fff}.spinner{width:20px;height:20px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.text-center{text-align:center}.text-muted{color:var(--color-text-muted)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.flex{display:flex}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.page{min-height:calc(100vh - 140px);padding:var(--space-lg) 0}.page-title{font-size:var(--text-3xl);font-weight:600;color:var(--color-text)}.layout .header{background-color:var(--color-surface);border-bottom:1px solid var(--color-border);padding:var(--space-md) 0}.layout .nav{display:flex;gap:var(--space-lg);align-items:center}.layout .nav-link{color:var(--color-text-secondary);transition:color .2s ease}.layout .nav-link:hover{color:var(--color-text)}.layout .user-menu{display:flex;align-items:center;gap:var(--space-md)}.layout .username{color:var(--color-text-secondary)}.layout .btn-logout{color:var(--color-text-muted);font-size:var(--text-sm)}.layout .btn-logout:hover{color:var(--color-error)}.layout .main{flex:1}.layout .footer{background-color:var(--color-bg-secondary);border-top:1px solid var(--color-border);padding:var(--space-lg) 0;margin-top:auto}.auth-page{min-height:100vh;background-color:var(--color-bg)}.auth-page .header{background-color:var(--color-surface);border-bottom:1px solid var(--color-border);padding:var(--space-md) 0}.logo{font-size:var(--text-xl);font-weight:600;color:var(--color-text)}.auth-card{max-width:400px;margin:var(--space-2xl) auto;padding:var(--space-xl)}.auth-title{font-size:var(--text-2xl);font-weight:600;text-align:center;margin-bottom:var(--space-lg)}.login-type-tabs{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg)}.login-type-tabs .tab{flex:1;padding:var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg);color:var(--color-text-secondary);font-size:var(--text-sm);transition:all .2s ease}.login-type-tabs .tab.active{background-color:var(--color-primary);color:var(--color-bg);border-color:var(--color-primary)}.auth-form .form-group{margin-bottom:var(--space-md)}.auth-form label{display:block;margin-bottom:var(--space-xs);font-size:var(--text-sm);font-weight:500;color:var(--color-text)}.input-with-btn{display:flex;gap:var(--space-sm)}.input-with-btn .input{flex:1}.btn-block{width:100%}.auth-footer{text-align:center;margin-top:var(--space-lg);font-size:var(--text-sm);color:var(--color-text-muted)}.auth-footer a{color:var(--color-primary)}.form-label{display:block;margin-bottom:var(--space-xs);font-size:var(--text-sm);font-weight:500;color:var(--color-text)}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-lg)}.product-card .product-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-sm)}.product-card .product-name{font-size:var(--text-lg);font-weight:600;color:var(--color-text)}.product-card .product-description{color:var(--color-text-secondary);font-size:var(--text-sm);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.product-card .product-category{margin-top:var(--space-sm)}.product-card .product-meta{display:flex;justify-content:space-between;align-items:center}.product-card .product-actions{display:flex;gap:var(--space-sm)}.empty-state{padding:var(--space-2xl)}.empty-state h3{font-size:var(--text-xl);color:var(--color-text)}.image-upload-area{display:flex;align-items:center;gap:var(--space-sm)}.uploaded-images{display:flex;flex-wrap:wrap;gap:var(--space-md)}.image-preview{position:relative;width:100px;height:100px}.image-preview img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-md)}.btn-remove{position:absolute;top:-8px;right:-8px;width:24px;height:24px;border-radius:50%;background-color:var(--color-error);color:#fff;font-size:18px;line-height:1}.product-title{font-size:var(--text-2xl);font-weight:600;color:var(--color-text)}.card-title{font-size:var(--text-xl);font-weight:600;color:var(--color-text)}.product-images .images-grid{display:flex;flex-wrap:wrap;gap:var(--space-md)}.product-image{width:200px;height:200px;object-fit:cover;border-radius:var(--radius-md)}.report-section h3{font-size:var(--text-lg);font-weight:600;color:var(--color-text)}.report-content{color:var(--color-text-secondary);line-height:1.8}.artist-prompt{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md);margin-top:var(--space-md)}.artist-prompt .report-content{white-space:pre-wrap;word-wrap:break-word}.generated-materials .images-grid,.generated-materials .videos-grid{display:flex;flex-wrap:wrap;gap:var(--space-md)}.generated-image{width:250px;height:250px;object-fit:cover;border-radius:var(--radius-md)}.generated-video{width:320px;border-radius:var(--radius-md)}.max-width-md{max-width:600px;margin:0 auto}.max-width-lg{max-width:900px;margin:0 auto}.ml-sm{margin-left:var(--space-sm)}.py-xl{padding-top:var(--space-xl);padding-bottom:var(--space-xl)}.text-error{color:var(--color-error)}.disabled{opacity:.5;cursor:not-allowed}.alert{padding:var(--space-md);border-radius:var(--radius-md);font-size:var(--text-sm)}.alert-error{background-color:#fef2f2;color:var(--color-error);border:1px solid #FEE2E2}.analysis-info h3{font-size:var(--text-lg);font-weight:600;color:var(--color-text);margin-bottom:var(--space-md)}.info-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md)}.info-label{font-weight:500;color:var(--color-text);margin-bottom:var(--space-sm)}.keywords-list{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.keyword-tag{padding:4px 12px;background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);font-size:var(--text-sm)}.info-summary{color:var(--color-text-secondary);font-size:var(--text-sm);line-height:1.6}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--space-md)}.stat-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md);text-align:center}.stat-label{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.stat-value{font-size:var(--text-2xl);font-weight:600;color:var(--color-text)}.platform-stats h3,.top-products h3{font-size:var(--text-lg);font-weight:600;color:var(--color-text);margin-bottom:var(--space-md)}.platform-list{display:flex;flex-direction:column;gap:var(--space-sm)}.platform-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md)}.platform-item-expanded{padding:var(--space-md);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--space-md)}.platform-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border)}.platform-stats-summary{display:flex;gap:var(--space-lg);font-size:var(--text-sm);color:var(--color-text-secondary)}.platform-champions{display:flex;flex-direction:column;gap:var(--space-sm);margin-top:var(--space-md)}.champion-item{display:flex;gap:var(--space-sm);align-items:flex-start;padding:var(--space-sm);background:var(--color-surface);border-radius:var(--radius-sm)}.champion-badge{padding:2px 8px;border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:500;white-space:nowrap}.champion-sales{background:#fef3c7;color:#92400e}.champion-price{background:#fee2e2;color:#991b1b}.champion-reviews{background:#d1fae5;color:#065f46}.champion-info{flex:1}.champion-title{font-size:var(--text-sm);font-weight:500;color:var(--color-text);margin-bottom:var(--space-xs)}.champion-meta{display:flex;gap:var(--space-md);font-size:var(--text-xs);color:var(--color-text-secondary)}.product-reviews{color:#059669}.step-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg)}.step-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border)}.step-number{width:40px;height:40px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--text-lg);flex-shrink:0}.step-title{flex:1;display:flex;align-items:center;gap:var(--space-md)}.step-title h2{font-size:var(--text-xl);font-weight:600;color:var(--color-text);margin:0}.step-status-success{padding:4px 12px;background:#d1fae5;color:#065f46;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500}.step-status-processing{padding:4px 12px;background:#fef3c7;color:#92400e;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500}.competition-data-card,.report-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-lg)}.competition-data-card h3,.competition-data-card h4,.report-card h3,.report-card h4{font-weight:600;color:var(--color-text);margin-bottom:var(--space-md)}.report-content h3{font-size:var(--text-lg);margin-top:0}.feedback-section{margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid var(--color-border)}.platform-name{font-weight:600;color:var(--color-text)}.platform-details{display:flex;gap:var(--space-lg);font-size:var(--text-sm);color:var(--color-text-secondary)}.products-list{display:flex;flex-direction:column;gap:var(--space-md)}.product-item{display:flex;gap:var(--space-md);padding:var(--space-md);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);align-items:flex-start}.product-rank{font-size:var(--text-lg);font-weight:600;color:var(--color-primary);min-width:30px}.product-info{flex:1}.product-title{font-weight:500;color:var(--color-text);margin-bottom:var(--space-xs)}.product-meta{display:flex;gap:var(--space-md);font-size:var(--text-sm);color:var(--color-text-secondary)}.product-platform{padding:2px 8px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.product-price{font-weight:600;color:var(--color-error)}.product-sales{color:var(--color-text-muted)}.edit-mode{background:var(--color-bg);padding:var(--space-md);border-radius:var(--radius-md)}.btn-sm{padding:4px 12px;font-size:var(--text-sm)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;background-color:var(--color-bg);color:var(--color-text);line-height:1.6}#root{min-height:100vh}
