@import"https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@600;700;900&family=DM+Sans:wght@400;500;600;700&display=swap";*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #FAF8F5;--bg-warm: #F5F0EA;--bg-deep: #EDE7DD;--primary: #2D6A4F;--primary-hover: #1B4332;--primary-light: #D8F3DC;--primary-ghost: rgba(45,106,79,.08);--accent: #E07A2F;--accent-light: #FFF0E0;--accent-ghost: rgba(224,122,47,.1);--text: #1A1A1A;--text-secondary: #7A7267;--text-tertiary: #A89F94;--border: #E8E0D6;--border-light: #F0EBE3;--card: #FFFFFF;--card-hover: #FEFDFB;--success: #40916C;--success-light: #D8F3DC;--danger: #C1292E;--danger-light: #FDECEA;--warning: #D4A017;--warning-light: #FFF8E1;--header-h: 56px;--radius: 12px;--radius-sm: 8px;--radius-xs: 6px;--shadow-sm: 0 1px 3px rgba(26,26,26,.04), 0 1px 2px rgba(26,26,26,.06);--shadow-md: 0 4px 12px rgba(26,26,26,.06), 0 2px 4px rgba(26,26,26,.04);--shadow-lg: 0 12px 32px rgba(26,26,26,.08), 0 4px 8px rgba(26,26,26,.04);--shadow-glow: 0 0 0 3px rgba(45,106,79,.15)}body{font-family:DM Sans,-apple-system,BlinkMacSystemFont,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-layout{display:flex;min-height:100vh;min-height:100dvh}.main-area{flex:1;min-height:100vh;min-height:100dvh;background:var(--bg);display:flex;flex-direction:column}.top-bar{height:var(--header-h);background:#faf8f5d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between;padding:0 32px;position:sticky;top:0;z-index:50}.store-switcher{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:600;color:var(--text)}.store-switcher .store-icon{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px}.store-switcher select{border:1px solid var(--border);border-radius:var(--radius-xs);padding:6px 12px;font-size:14px;font-weight:600;background:var(--card);color:var(--text);cursor:pointer;transition:border-color .2s}.store-switcher select:hover{border-color:var(--primary)}.user-info{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-secondary)}.user-info .avatar{width:32px;height:32px;border-radius:50%;background:var(--primary-light);color:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}@keyframes pageIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.mobile-menu-btn{display:none}.tab-bar{position:fixed;bottom:0;left:0;right:0;height:64px;background:#ffffffeb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--border-light);display:flex;align-items:stretch;justify-content:space-around;z-index:100;padding-bottom:env(safe-area-inset-bottom,0px)}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;border:none;background:none;cursor:pointer;padding:6px 0;transition:all .2s ease;-webkit-tap-highlight-color:transparent;position:relative}.tab-item:active{transform:scale(.92)}.tab-icon{font-size:22px;line-height:1;transition:transform .2s ease}.tab-item.active .tab-icon{transform:scale(1.15)}.tab-label{font-size:10px;font-weight:500;color:var(--text-tertiary);letter-spacing:.02em;transition:color .2s ease}.tab-item.active .tab-label{color:var(--primary);font-weight:700}.tab-item.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:24px;height:3px;background:var(--primary);border-radius:0 0 3px 3px}.page-content{padding:24px 32px;padding-bottom:calc(88px + env(safe-area-inset-bottom,0px));max-width:1280px;flex:1;animation:pageIn .35s ease-out}.card{background:var(--card);border:1px solid var(--border-light);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm);transition:box-shadow .2s ease,transform .2s ease}.card:hover{box-shadow:var(--shadow-md)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.card-header h3{font-family:"Noto Serif SC",serif;font-size:17px;font-weight:700;color:var(--text)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:28px}.stat-card{background:var(--card);border:1px solid var(--border-light);border-radius:var(--radius);padding:20px 24px;box-shadow:var(--shadow-sm);transition:all .2s ease;position:relative;overflow:hidden}.stat-card:after{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--accent));opacity:0;transition:opacity .2s}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-card:hover:after{opacity:1}.stat-card .label{font-size:12px;color:var(--text-tertiary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em;font-weight:600}.stat-card .value{font-family:DM Sans,sans-serif;font-size:32px;font-weight:700;color:var(--primary);line-height:1.1}.stat-card .sub{font-size:12px;color:var(--text-tertiary);margin-top:4px}.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:all .2s ease;white-space:nowrap}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px #2d6a4f33}.btn-primary:hover{background:var(--primary-hover);box-shadow:0 4px 12px #2d6a4f4d;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.btn-outline{background:var(--card);color:var(--text);border-color:var(--border)}.btn-outline:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-ghost)}.btn-danger{background:var(--danger);color:#fff;box-shadow:0 2px 8px #c1292e33}.btn-danger:hover{background:#a31f23}.btn-accent{background:var(--accent);color:#fff;box-shadow:0 2px 8px #e07a2f33}.btn-accent:hover{background:#c86a22}.btn-sm{padding:5px 12px;font-size:12px}.form-group{margin-bottom:18px}.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:6px;letter-spacing:.01em}.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;background:var(--card);color:var(--text);transition:all .2s ease}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:var(--shadow-glow)}.form-group input:disabled{background:var(--bg-warm);color:var(--text-tertiary)}.form-group textarea{resize:vertical;min-height:88px;line-height:1.6}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-section{margin-bottom:28px}.form-section h4{font-family:"Noto Serif SC",serif;font-size:15px;font-weight:700;color:var(--primary);margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid var(--primary-light);display:flex;align-items:center;gap:8px}.form-section h4:before{content:"";width:4px;height:16px;background:var(--primary);border-radius:2px}.checkbox-label{display:flex!important;align-items:center;gap:8px;cursor:pointer;font-weight:400!important;padding:6px 0}.checkbox-label input[type=checkbox]{width:18px!important;height:18px;accent-color:var(--primary);border-radius:4px}.multi-select-grid{display:flex;flex-wrap:wrap;gap:8px}.multi-select-item{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:1.5px solid var(--border);border-radius:24px;background:var(--card);font-size:13px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;white-space:nowrap;font-weight:500}.multi-select-item:hover{border-color:var(--primary);color:var(--text);background:var(--primary-ghost)}.multi-select-item.selected{border-color:var(--primary);background:var(--primary-light);color:var(--primary);font-weight:600;box-shadow:0 1px 4px #2d6a4f26}.folder-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px;padding:4px;background:var(--bg-warm);border-radius:var(--radius)}.folder-tab{padding:8px 16px;font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;border:1.5px solid transparent;background:transparent;border-radius:var(--radius-sm);white-space:nowrap;transition:all .2s ease}.folder-tab:hover{color:var(--text);background:var(--card)}.folder-tab.active{color:var(--primary);font-weight:600;background:var(--card);border-color:var(--primary);box-shadow:var(--shadow-sm)}.folder-tab .count{font-size:10px;background:var(--border-light);padding:1px 7px;border-radius:10px;margin-left:4px;font-weight:600}.folder-tab.active .count{background:var(--primary-light);color:var(--primary)}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}.image-card{background:var(--card);border:1.5px solid var(--border-light);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:all .25s ease;position:relative}.image-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--border)}.image-card.selected{border-color:var(--primary);box-shadow:var(--shadow-glow),var(--shadow-md)}.image-card img{width:100%;aspect-ratio:4/5;object-fit:cover;display:block}.image-card .info{padding:10px 12px}.image-card .info .name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}.image-card .info .meta{font-size:11px;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.image-card .check-mark{position:absolute;top:10px;right:10px;width:24px;height:24px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;box-shadow:0 2px 6px #2d6a4f4d}.image-card .ai-badge{position:absolute;top:10px;left:10px;font-size:10px;font-weight:700;background:var(--primary);color:#fff;padding:3px 8px;border-radius:6px;letter-spacing:.02em;box-shadow:0 1px 4px #2d6a4f33}.character-card{display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--card);border:1.5px solid var(--border-light);border-radius:var(--radius);cursor:pointer;transition:all .25s ease}.character-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-1px)}.character-card.character-add{justify-content:center;flex-direction:column;border-style:dashed;border-color:var(--border);min-height:88px}.character-card.character-add:hover{border-color:var(--primary);background:var(--primary-ghost)}.character-avatar{font-size:28px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--primary-light);border-radius:50%;flex-shrink:0;border:2px solid rgba(45,106,79,.1)}.character-info{flex:1;min-width:0}.character-name{font-size:14px;font-weight:700;color:var(--text)}.character-role{font-size:12px;color:var(--primary);font-weight:600}.character-style{font-size:11px;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.avatar-option{width:44px;height:44px;font-size:22px;border:2px solid var(--border);border-radius:50%;background:var(--card);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.avatar-option:hover{border-color:var(--primary);transform:scale(1.1)}.avatar-option.active{border-color:var(--primary);background:var(--primary-light);box-shadow:var(--shadow-glow)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#1a1a1a80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .2s ease}.modal{background:var(--card);border-radius:16px;width:100%;max-width:540px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:modalIn .25s ease}@keyframes modalIn{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-light)}.modal-header h3{font-family:"Noto Serif SC",serif;font-size:18px;font-weight:700}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border-light);display:flex;justify-content:flex-end;gap:10px}.checkbox-row{display:flex;align-items:flex-start;gap:10px;font-size:13px;margin:14px 0;line-height:1.5}.checkbox-row input[type=checkbox]{margin-top:4px;accent-color:var(--primary);width:18px;height:18px}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:48px 24px;text-align:center;color:var(--text-secondary);cursor:pointer;transition:all .25s ease;background:var(--bg)}.drop-zone:hover,.drop-zone.dragover{border-color:var(--primary);background:var(--primary-ghost);color:var(--primary)}.drop-zone .icon{font-size:40px;margin-bottom:12px;display:block}.gen-layout{display:grid;grid-template-columns:1fr 1fr;gap:24px}.gen-panel{background:var(--card);border:1px solid var(--border-light);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm)}.gen-panel h3{font-family:"Noto Serif SC",serif;font-size:16px;font-weight:700;margin-bottom:20px;color:var(--text)}.prompt-box{background:var(--bg-warm);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:16px;font-size:13px;line-height:1.8;max-height:320px;overflow-y:auto;white-space:pre-wrap;word-break:break-word}.prompt-box textarea{width:100%;min-height:220px;border:none;background:transparent;font-size:13px;line-height:1.8;resize:vertical;color:var(--text);font-family:inherit}.prompt-box textarea:focus{outline:none}.review-item{display:flex;gap:14px;padding:14px;border:1px solid var(--border-light);border-radius:var(--radius);margin-bottom:10px;background:var(--card)}.review-item img{width:80px;height:100px;object-fit:cover;border-radius:var(--radius-xs)}.review-item .details{flex:1}.review-status{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:6px;font-size:12px;font-weight:600}.review-status.pass{background:var(--success-light);color:var(--success)}.review-status.fail{background:var(--danger-light);color:var(--danger)}.review-status.warn{background:var(--warning-light);color:var(--warning)}.progress-bar{height:6px;background:var(--bg-deep);border-radius:3px;overflow:hidden}.progress-bar .fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:3px;transition:width .5s ease}.empty-state{text-align:center;padding:64px 24px;color:var(--text-tertiary)}.empty-state .icon{font-size:56px;margin-bottom:16px;opacity:.25}.empty-state h4{font-family:"Noto Serif SC",serif;font-size:18px;color:var(--text);margin-bottom:6px}.empty-state p{font-size:14px}.tag{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:6px;font-size:11px;font-weight:600;letter-spacing:.02em}.tag-green{background:var(--success-light);color:var(--success)}.tag-red{background:var(--danger-light);color:var(--danger)}.tag-amber{background:var(--warning-light);color:var(--warning)}.tag-blue{background:#e8f0fe;color:#1a73e8}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13px}table th{text-align:left;padding:12px 16px;font-weight:600;color:var(--text-tertiary);border-bottom:2px solid var(--border-light);font-size:11px;text-transform:uppercase;letter-spacing:.06em}table td{padding:12px 16px;border-bottom:1px solid var(--border-light)}table tr:hover td{background:var(--primary-ghost)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}.page-header h2{font-family:"Noto Serif SC",serif;font-size:24px;font-weight:900;color:var(--text);line-height:1.3}.page-header .subtitle{font-size:14px;color:var(--text-tertiary);margin-top:2px}.page-header .actions{display:flex;gap:10px}.quick-action{display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--card);border:1.5px solid var(--border-light);border-radius:var(--radius);cursor:pointer;transition:all .25s ease;text-align:left;width:100%}.quick-action:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.quick-action .qa-icon{width:44px;height:44px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.quick-action .qa-text{flex:1;min-width:0}.quick-action .qa-title{font-size:14px;font-weight:600;color:var(--text)}.quick-action .qa-desc{font-size:12px;color:var(--text-tertiary);margin-top:1px}.tip-banner{background:var(--accent-light);border:1px solid rgba(224,122,47,.2);border-radius:var(--radius);padding:16px 20px;display:flex;gap:12px;align-items:flex-start}.tip-banner .tip-icon{font-size:20px;flex-shrink:0;margin-top:1px}.tip-banner .tip-title{font-weight:700;font-size:14px;color:var(--accent);margin-bottom:2px}.tip-banner .tip-text{font-size:13px;color:var(--text-secondary);line-height:1.6}.step-indicator{display:flex;gap:0;margin-bottom:24px;background:var(--card);border-radius:var(--radius);border:1px solid var(--border-light);overflow:hidden;box-shadow:var(--shadow-sm)}.step-item{flex:1;padding:12px 16px;text-align:center;font-size:13px;font-weight:500;transition:all .25s ease;position:relative;color:var(--text-tertiary)}.step-item.active{color:var(--primary);font-weight:700;background:var(--primary-ghost)}.step-item.done{color:var(--primary);background:var(--primary-light)}.step-item+.step-item{border-left:1px solid var(--border-light)}.step-num{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;font-size:11px;font-weight:700;margin-right:6px;background:var(--border-light);color:var(--text-tertiary)}.step-item.active .step-num,.step-item.done .step-num{background:var(--primary);color:#fff}@media (max-width: 768px){.top-bar{padding:0 16px}.page-content{padding:16px;padding-bottom:calc(80px + env(safe-area-inset-bottom,0px))}.gen-layout,.form-row{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr}.image-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}.modal{max-width:100%;margin:8px;max-height:90vh;border-radius:12px}.card{padding:18px}.page-header{flex-direction:column;align-items:flex-start;gap:12px}.page-header h2{font-size:20px}.character-card{padding:12px 14px}.step-indicator{font-size:12px}.tab-bar{height:56px}.tab-icon{font-size:20px}.tab-label{font-size:9px}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}.image-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.store-switcher select{max-width:140px}.multi-select-item{padding:6px 12px;font-size:12px}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn .3s ease-out}.spinner{display:inline-block;width:20px;height:20px;border:2.5px solid var(--border-light);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-layout:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;opacity:.015;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");z-index:9999}
