:root{--bg: #08080c;--bg-1: #0d0d14;--bg-2: #12121b;--bg-3: #1a1a25;--bg-4: #22222e;--border: rgba(255, 255, 255, .06);--border-2: rgba(255, 255, 255, .1);--border-strong: rgba(255, 255, 255, .16);--text: #f5f5f7;--text-muted: #9999a8;--text-soft: #65656f;--violet: #a855f7;--blue: #3b82f6;--cyan: #06b6d4;--brand: var(--violet);--brand-2: var(--blue);--grad-brand: linear-gradient(135deg, #a855f7 0%, #3b82f6 50%, #06b6d4 100%);--grad-brand-soft: linear-gradient(135deg, rgba(168, 85, 247, .16) 0%, rgba(59, 130, 246, .16) 50%, rgba(6, 182, 212, .16) 100%);--grad-text: linear-gradient(135deg, #c4b5fd 0%, #93c5fd 50%, #67e8f9 100%);--success: #10b981;--success-bg: rgba(16, 185, 129, .12);--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .12);--danger: #ef4444;--danger-bg: rgba(239, 68, 68, .12);--glass: rgba(255, 255, 255, .025);--glass-2: rgba(255, 255, 255, .04);--glow-brand: 0 0 32px rgba(168, 85, 247, .22);--glow-blue: 0 0 32px rgba(59, 130, 246, .22);--shadow: 0 4px 16px rgba(0, 0, 0, .4);--shadow-md: 0 8px 32px rgba(0, 0, 0, .5);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .6)}*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,Inter,Helvetica Neue,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased;font-feature-settings:"cv11","ss01";letter-spacing:.005em}body:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse 80% 60% at 20% 0%,rgba(168,85,247,.08) 0%,transparent 50%),radial-gradient(ellipse 60% 50% at 80% 0%,rgba(59,130,246,.06) 0%,transparent 50%);pointer-events:none;z-index:0}body>*{position:relative;z-index:1}a{color:#93c5fd;text-decoration:none}a:hover{color:#c4b5fd}::selection{background:#a855f74d;color:#fff}.topnav{height:60px;background:#08080cb3;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 28px;position:sticky;top:0;z-index:100}.topnav .logo{display:flex;align-items:center;gap:10px;font-weight:600;font-size:14px;color:var(--text);margin-right:32px;text-decoration:none;letter-spacing:.02em}.topnav .logo-mark{width:30px;height:30px;border-radius:9px;background:var(--grad-brand);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px;box-shadow:var(--glow-brand);font-family:Inter,-apple-system,sans-serif;letter-spacing:-.04em}.topnav .logo-text{display:flex;flex-direction:column;line-height:1.1}.topnav .logo-text .logo-zh{font-size:14px;font-weight:600;letter-spacing:.02em}.topnav .logo-text .logo-en{font-size:10px;color:var(--text-soft);font-weight:500;letter-spacing:.12em;text-transform:uppercase}.topnav .nav-links{display:flex;gap:2px;flex:1}.topnav .nav-link{padding:8px 14px;border-radius:8px;color:var(--text-muted);font-size:13px;cursor:pointer;text-decoration:none;transition:all .15s}.topnav .nav-link:hover{color:var(--text);background:var(--glass)}.topnav .nav-link.active{color:var(--text);background:var(--glass-2)}.topnav .right{display:flex;align-items:center;gap:10px}.topnav .credits{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--glass-2);border:1px solid var(--border);border-radius:8px;font-size:12px;color:var(--text);font-weight:500}.topnav .credits .icon{background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent;font-size:11px}.topnav .avatar{width:32px;height:32px;border-radius:50%;background:var(--grad-brand);display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:600;cursor:pointer;box-shadow:var(--glow-brand)}.topnav .badge-trial{padding:3px 10px;background:var(--warning-bg);color:var(--warning);border:1px solid rgba(245,158,11,.2);border-radius:6px;font-size:11px;font-weight:500}.container{max-width:1280px;margin:0 auto;padding:40px 28px}.container.wide{max-width:100%;padding:24px 32px}.container.narrow{max-width:920px}.page-title{font-size:28px;font-weight:600;margin:0 0 8px;letter-spacing:-.02em}.page-title.gradient{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.page-subtitle{color:var(--text-muted);margin:0 0 32px;font-size:14px}.card{background:var(--bg-1);border:1px solid var(--border);border-radius:14px;transition:border-color .2s,transform .2s}.card.hover:hover{border-color:var(--border-2)}.card-header{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.card-title{font-size:15px;font-weight:600;margin:0;letter-spacing:-.01em}.card-body{padding:22px}.card-glass{background:linear-gradient(180deg,#ffffff0a,#ffffff03),var(--bg-1);border:1px solid var(--border-2);border-radius:14px;position:relative;overflow:hidden}.card-glass:before{content:"";position:absolute;inset:0;background:var(--grad-brand-soft);opacity:.4;pointer-events:none}.card-glass>*{position:relative}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 16px;border:1px solid var(--border-strong);background:var(--bg-3);color:var(--text);border-radius:9px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;text-decoration:none;white-space:nowrap;font-family:inherit;letter-spacing:.005em}.btn:hover{background:var(--bg-4);border-color:var(--border-strong);color:var(--text)}.btn.primary{background:var(--grad-brand);border:1px solid transparent;color:#fff;font-weight:500;box-shadow:0 1px #ffffff1a inset,var(--glow-brand)}.btn.primary:hover{filter:brightness(1.1);box-shadow:0 1px #ffffff1a inset,0 0 40px #a855f766}.btn.ghost{background:transparent;border-color:transparent;color:var(--text-muted)}.btn.ghost:hover{background:var(--glass);color:var(--text)}.btn.outline{background:transparent;border-color:var(--border-strong)}.btn.danger{color:var(--danger);border-color:#ef44444d;background:var(--danger-bg)}.btn.danger:hover{border-color:var(--danger)}.btn.sm{padding:6px 12px;font-size:12px;border-radius:7px}.btn.lg{padding:12px 22px;font-size:14px}.btn.block{width:100%}.tag{display:inline-flex;align-items:center;padding:3px 9px;border-radius:6px;font-size:11px;font-weight:500;background:var(--glass-2);color:var(--text-muted);border:1px solid var(--border);letter-spacing:.01em}.tag.brand{background:#a855f71f;color:#c4b5fd;border-color:#a855f733}.tag.success{background:var(--success-bg);color:var(--success);border-color:#10b98133}.tag.warning{background:var(--warning-bg);color:var(--warning);border-color:#f59e0b33}.tag.danger{background:var(--danger-bg);color:var(--danger);border-color:#ef444433}.input,.textarea,.select{width:100%;padding:10px 14px;border:1px solid var(--border-strong);border-radius:9px;font-size:13px;background:var(--bg-2);color:var(--text);font-family:inherit;transition:border-color .15s,box-shadow .15s}.input::placeholder,.textarea::placeholder{color:var(--text-soft)}.input:focus,.textarea:focus,.select:focus{outline:none;border-color:#a855f799;box-shadow:0 0 0 3px #a855f726}.textarea{resize:vertical;min-height:90px}.select option{background:var(--bg-2);color:var(--text)}.label{display:block;font-size:12px;font-weight:500;color:var(--text-muted);margin-bottom:7px;letter-spacing:.02em}.field{margin-bottom:18px}.help-text{font-size:12px;color:var(--text-soft);margin-top:6px}.row{display:flex;gap:16px}.col{flex:1}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.hero{padding:56px 0 40px;position:relative}.hero h1{font-size:42px;font-weight:600;margin:0 0 12px;letter-spacing:-.025em;line-height:1.1}.hero h1 .accent{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.hero p{font-size:16px;color:var(--text-muted);margin:0;max-width:580px}.stat-card{background:var(--bg-1);border:1px solid var(--border);border-radius:14px;padding:22px;position:relative;overflow:hidden}.stat-card .stat-label{font-size:12px;color:var(--text-muted);margin-bottom:8px;letter-spacing:.04em;text-transform:uppercase}.stat-card .stat-value{font-size:26px;font-weight:600;letter-spacing:-.02em}.stat-card .stat-value.gradient{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.stat-card .stat-extra{font-size:12px;color:var(--text-soft);margin-top:4px}.stat-card .stat-icon{position:absolute;top:18px;right:18px;width:36px;height:36px;border-radius:9px;background:var(--glass-2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:16px;opacity:.7}.project-card{background:var(--bg-1);border:1px solid var(--border);border-radius:14px;overflow:hidden;cursor:pointer;transition:all .2s;text-decoration:none;color:inherit;display:block}.project-card:hover{border-color:var(--border-strong);transform:translateY(-3px);box-shadow:var(--shadow)}.project-cover{height:140px;position:relative;display:flex;align-items:center;justify-content:center;font-size:36px;color:#ffffffd9;overflow:hidden}.project-cover.violet{background:linear-gradient(135deg,#4c1d95,#7c3aed,#a855f7)}.project-cover.blue{background:linear-gradient(135deg,#1e3a8a,#3b82f6,#06b6d4)}.project-cover.pink{background:linear-gradient(135deg,#831843,#db2777,#f472b6)}.project-cover.gray{background:linear-gradient(135deg,#1f2937,#4b5563)}.project-cover:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.15),transparent 50%)}.project-card .project-body{padding:18px 20px}.project-card .project-name{font-weight:600;font-size:15px;margin-bottom:6px;letter-spacing:-.01em}.project-card .project-meta{font-size:12px;color:var(--text-muted);margin-bottom:12px}.project-card .project-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.project-card .project-update{font-size:12px;color:var(--text-soft)}.capability-card{background:var(--bg-1);border:1px solid var(--border);border-radius:14px;padding:24px;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}.capability-card:hover{border-color:var(--border-strong);transform:translateY(-2px)}.capability-card:after{content:"";position:absolute;inset:0;background:var(--grad-brand-soft);opacity:0;transition:opacity .2s;pointer-events:none}.capability-card:hover:after{opacity:1}.capability-card>*{position:relative}.capability-card .icon{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:14px;background:var(--glass-2);border:1px solid var(--border)}.capability-card .icon.violet{background:linear-gradient(135deg,#a855f733,#7c3aed1a);border-color:#a855f74d}.capability-card .icon.blue{background:linear-gradient(135deg,#3b82f633,#2563eb1a);border-color:#3b82f64d}.capability-card .icon.pink{background:linear-gradient(135deg,#f472b633,#db27771a);border-color:#f472b64d}.capability-card h3{margin:0 0 6px;font-size:15px;font-weight:600;letter-spacing:-.01em}.capability-card p{margin:0;color:var(--text-muted);font-size:13px;line-height:1.5}.capability-card .options{margin-top:14px;display:flex;flex-wrap:wrap;gap:6px}.workspace{display:grid;grid-template-columns:260px 1fr;min-height:calc(100vh - 60px)}.sidebar{background:var(--bg-1);border-right:1px solid var(--border);padding:24px 16px;overflow-y:auto}.sidebar .project-info{padding:14px;background:var(--glass-2);border:1px solid var(--border);border-radius:10px;margin-bottom:20px}.sidebar .project-info .name{font-weight:600;font-size:14px;margin-bottom:4px;letter-spacing:-.01em}.sidebar .project-info .meta{font-size:12px;color:var(--text-muted)}.sidebar .nav-section{font-size:11px;font-weight:500;color:var(--text-soft);text-transform:uppercase;margin:18px 8px 6px;letter-spacing:.08em}.sidebar .nav-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-radius:8px;font-size:13px;color:var(--text-muted);cursor:pointer;margin-bottom:1px;text-decoration:none;transition:all .12s}.sidebar .nav-item:hover{background:var(--glass);color:var(--text)}.sidebar .nav-item.active{background:var(--glass-2);color:var(--text);border:1px solid var(--border)}.sidebar .nav-item .count{font-size:11px;background:var(--bg-3);color:var(--text-muted);padding:1px 7px;border-radius:8px;border:1px solid var(--border)}.workspace-main{padding:32px 36px;overflow-y:auto}.version-list .version-item{background:var(--bg-1);border:1px solid var(--border);border-radius:11px;padding:18px 22px;margin-bottom:10px;display:grid;grid-template-columns:1fr auto;align-items:center;gap:16px;transition:border-color .15s}.version-item:hover{border-color:var(--border-2)}.version-item .v-name{font-weight:600;font-size:14px;display:flex;align-items:center;gap:8px;letter-spacing:-.01em}.version-item .v-meta{font-size:12px;color:var(--text-muted);margin-top:5px}.version-item .v-actions{display:flex;gap:6px}.editor-layout{display:grid;grid-template-columns:1fr 340px;height:calc(100vh - 60px);background:var(--bg)}.editor-main{display:flex;flex-direction:column;border-right:1px solid var(--border);overflow:hidden}.editor-toolbar{padding:10px 18px;border-bottom:1px solid var(--border);background:var(--bg-1);display:flex;align-items:center;gap:8px;flex-wrap:wrap}.editor-toolbar .sep{width:1px;height:18px;background:var(--border-strong)}.editor-grid{flex:1;overflow:auto;padding:0;background:var(--bg)}.grid-table{width:100%;border-collapse:collapse;font-size:13px}.grid-table th{background:var(--bg-1);padding:12px 14px;border-bottom:1px solid var(--border);border-right:1px solid var(--border);font-weight:500;font-size:11px;color:var(--text-muted);text-align:left;position:sticky;top:0;z-index:10;letter-spacing:.06em;text-transform:uppercase}.grid-table td{padding:12px 14px;border-bottom:1px solid var(--border);border-right:1px solid var(--border);vertical-align:top;color:var(--text)}.grid-table tr:hover td{background:var(--glass)}.grid-table .row-num{width:50px;background:var(--bg-1);color:var(--text-soft);text-align:center;font-size:12px;font-variant-numeric:tabular-nums}.grid-table td.character{font-weight:500;color:#c4b5fd}.grid-table td.dialogue{color:var(--text)}.grid-table td.action{color:var(--text-muted);font-style:italic}.editor-side{background:var(--bg-1);overflow-y:auto}.ai-panel-card{border-bottom:1px solid var(--border);padding:18px 20px}.ai-panel-card.featured{background:var(--grad-brand-soft);position:relative}.ai-panel-card.featured:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(168,85,247,.06),transparent);pointer-events:none}.ai-panel-card.featured>*{position:relative}.ai-panel-card h4{margin:0 0 6px;font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:space-between;letter-spacing:-.01em}.ai-panel-card.featured h4{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.ai-panel-card h4 .arrow{color:var(--text-soft);font-weight:400}.ai-panel-card .desc{font-size:12px;color:var(--text-muted);margin-bottom:12px;line-height:1.5}.ai-panel-card .estimate{font-size:11px;color:#c4b5fd;margin-top:10px;font-weight:500;letter-spacing:.02em}.slider-row{display:flex;align-items:center;gap:12px;margin-bottom:8px}.slider{flex:1;-webkit-appearance:none;appearance:none;height:6px;background:var(--bg-3);border-radius:3px;outline:none;border:1px solid var(--border)}.slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:var(--grad-brand);border-radius:50%;cursor:pointer;box-shadow:var(--glow-brand);border:2px solid #fff}.slider-value{font-size:13px;font-weight:600;color:#c4b5fd;min-width:40px;text-align:right;font-variant-numeric:tabular-nums}.chip-group{display:flex;flex-wrap:wrap;gap:6px}.chip{padding:6px 13px;border:1px solid var(--border-strong);border-radius:16px;font-size:12px;cursor:pointer;background:var(--glass);color:var(--text-muted);transition:all .15s;letter-spacing:.005em}.chip:hover{border-color:#a855f766;color:var(--text)}.chip.selected{background:var(--grad-brand);color:#fff;border-color:transparent;box-shadow:0 0 12px #a855f74d}.review-item{background:var(--bg-1);border:1px solid var(--border);border-radius:12px;padding:20px 22px;margin-bottom:12px;transition:border-color .15s}.review-item:hover{border-color:var(--border-2)}.review-item .head{display:flex;align-items:center;gap:8px;margin-bottom:10px}.review-item .location{font-size:12px;color:var(--text-muted);background:var(--glass-2);padding:2px 9px;border-radius:5px;border:1px solid var(--border)}.review-item .problem{font-weight:600;font-size:14px;margin-bottom:8px;letter-spacing:-.01em}.review-item .suggest{background:var(--grad-brand-soft);border-left:2px solid var(--violet);padding:12px 14px;border-radius:6px;font-size:13px;color:var(--text);margin:12px 0;line-height:1.6}.review-item .actions{display:flex;gap:6px;margin-top:12px}.tier-card{background:var(--bg-1);border:1px solid var(--border-2);border-radius:16px;padding:32px 28px;position:relative;transition:all .2s}.tier-card:hover{transform:translateY(-2px)}.tier-card.recommended{border:1px solid transparent;background:linear-gradient(var(--bg-1),var(--bg-1)) padding-box,var(--grad-brand) border-box;box-shadow:var(--glow-brand)}.tier-card .badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:var(--grad-brand);color:#fff;padding:4px 14px;border-radius:10px;font-size:11px;font-weight:600;letter-spacing:.05em;box-shadow:var(--glow-brand)}.tier-card .name{font-size:16px;font-weight:600;margin-bottom:6px;letter-spacing:-.01em}.tier-card .price{font-size:36px;font-weight:700;margin:14px 0;letter-spacing:-.03em}.tier-card .price small{font-size:14px;color:var(--text-muted);font-weight:400;letter-spacing:0}.tier-card .features{list-style:none;padding:0;margin:18px 0}.tier-card .features li{padding:7px 0;font-size:13px;color:var(--text-muted);display:flex;align-items:center;gap:10px}.tier-card .features li:before{content:"✓";color:var(--cyan);font-weight:600}.upload-zone{border:1.5px dashed var(--border-strong);border-radius:14px;padding:56px 24px;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg-1);position:relative;overflow:hidden}.upload-zone:before{content:"";position:absolute;inset:0;background:var(--grad-brand-soft);opacity:0;transition:opacity .2s}.upload-zone:hover{border-color:#a855f780}.upload-zone:hover:before{opacity:1}.upload-zone>*{position:relative}.upload-zone .icon{font-size:36px;margin-bottom:14px;opacity:.9}.video-row{display:grid;grid-template-columns:80px 1fr auto auto;align-items:center;gap:16px;padding:14px 18px;background:var(--bg-1);border:1px solid var(--border);border-radius:11px;margin-bottom:8px;transition:border-color .15s}.video-row:hover{border-color:var(--border-2)}.video-row .thumb{width:80px;height:48px;background:var(--bg-3);border:1px solid var(--border);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--text-soft)}.video-row .info .name{font-weight:500;font-size:14px;letter-spacing:-.01em}.video-row .info .meta{font-size:12px;color:var(--text-muted);margin-top:3px}.video-row .ttl{font-size:12px;color:var(--warning)}.progress{height:5px;background:var(--bg-3);border-radius:3px;overflow:hidden;border:1px solid var(--border)}.progress .bar{height:100%;background:var(--grad-brand);border-radius:3px;transition:width .3s;box-shadow:0 0 12px #a855f766}.modal-mask{position:fixed;inset:0;background:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:200}.modal{background:var(--bg-2);border:1px solid var(--border-2);border-radius:16px;width:480px;max-width:90vw;box-shadow:var(--shadow-lg);overflow:hidden}.modal-header{padding:18px 22px;border-bottom:1px solid var(--border);font-weight:600;font-size:15px;display:flex;justify-content:space-between;align-items:center;letter-spacing:-.01em}.modal-body{padding:22px}.modal-footer{padding:14px 22px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}.tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:24px;gap:4px}.tab{padding:12px 16px;font-size:13px;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s}.tab:hover{color:var(--text)}.tab.active{color:var(--text);border-bottom-color:var(--violet)}.tab .count{font-size:11px;background:var(--glass-2);padding:1px 7px;border-radius:8px;margin-left:6px;border:1px solid var(--border)}.activity-list .activity-item{display:grid;grid-template-columns:auto 1fr auto;gap:14px;padding:14px 0;border-bottom:1px solid var(--border);align-items:center}.activity-list .activity-item:last-child{border-bottom:none}.activity-icon{width:32px;height:32px;border-radius:8px;background:var(--glass-2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:14px}.activity-list .activity-name{font-size:13px;color:var(--text);font-weight:500;letter-spacing:-.01em}.activity-list .activity-meta{font-size:12px;color:var(--text-muted);margin-top:2px}.activity-list .activity-credits{font-size:12px;font-variant-numeric:tabular-nums;font-weight:500}.text-muted{color:var(--text-muted)}.text-soft{color:var(--text-soft)}.text-brand{color:#c4b5fd}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.text-sm{font-size:12px}.text-xs{font-size:11px}.fw-600{font-weight:600}.gradient-text{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.mt-0{margin-top:0}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}.mb-0{margin-bottom:0}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.mb-32{margin-bottom:32px}.flex{display:flex}.flex-1{flex:1}.flex-between{display:flex;justify-content:space-between;align-items:center}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.items-center{align-items:center}.view-toggle{display:inline-flex;background:var(--bg-2);border:1px solid var(--border);border-radius:9px;padding:3px;gap:2px}.view-toggle .toggle-item{padding:6px 14px;border-radius:6px;font-size:12px;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .15s}.view-toggle .toggle-item.active{background:var(--bg-4);color:var(--text);box-shadow:0 1px 2px #0000004d}.canvas-layout{position:relative;height:calc(100vh - 60px);background:var(--bg);background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.04) 1px,transparent 0);background-size:20px 20px;overflow:hidden}.canvas-toolbar{position:absolute;left:16px;top:50%;transform:translateY(-50%);background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:6px;display:flex;flex-direction:column;gap:4px;z-index:10;backdrop-filter:blur(20px)}.canvas-toolbar .tool{width:38px;height:38px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted);font-size:16px;transition:all .15s}.canvas-toolbar .tool:hover{background:var(--glass-2);color:var(--text)}.canvas-toolbar .tool.active{background:var(--glass-2);color:#c4b5fd}.canvas-statusbar{position:absolute;bottom:16px;left:16px;background:var(--bg-2);border:1px solid var(--border);border-radius:10px;padding:4px 6px;display:flex;align-items:center;gap:4px;z-index:10;backdrop-filter:blur(20px)}.canvas-statusbar .icon-btn{padding:6px 10px;border-radius:6px;cursor:pointer;color:var(--text-muted);font-size:13px;transition:all .15s}.canvas-statusbar .icon-btn:hover{background:var(--glass-2);color:var(--text)}.canvas-statusbar .zoom-display{padding:6px 10px;font-size:12px;color:var(--text-muted);font-variant-numeric:tabular-nums;min-width:56px;text-align:center}.canvas-topright{position:absolute;top:16px;right:16px;display:flex;gap:8px;z-index:10}.canvas-node{position:absolute;background:var(--bg-2);border:1px solid var(--border-2);border-radius:12px;min-width:180px;cursor:grab;transition:border-color .15s,box-shadow .15s;overflow:hidden;user-select:none}.canvas-node:hover{border-color:var(--border-strong)}.canvas-node.selected{border-color:#a855f799;box-shadow:0 0 0 2px #a855f733,0 0 24px #a855f740}.canvas-node .node-header{padding:10px 14px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border);background:var(--bg-1)}.canvas-node .node-icon{width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px}.canvas-node .node-icon.violet{background:#a855f733;border:1px solid rgba(168,85,247,.3)}.canvas-node .node-icon.blue{background:#3b82f633;border:1px solid rgba(59,130,246,.3)}.canvas-node .node-icon.cyan{background:#06b6d433;border:1px solid rgba(6,182,212,.3)}.canvas-node .node-icon.pink{background:#f472b633;border:1px solid rgba(244,114,182,.3)}.canvas-node .node-icon.orange{background:#fb923c33;border:1px solid rgba(251,146,60,.3)}.canvas-node .node-icon.gray{background:var(--glass-2);border:1px solid var(--border)}.canvas-node .node-title{font-size:13px;font-weight:500;letter-spacing:-.005em}.canvas-node .node-status{margin-left:auto;width:6px;height:6px;border-radius:50%;background:var(--text-soft)}.canvas-node .node-status.success{background:var(--success);box-shadow:0 0 6px var(--success)}.canvas-node .node-status.running{background:var(--cyan);box-shadow:0 0 6px var(--cyan);animation:pulse 1.6s infinite}.canvas-node .node-status.error{background:var(--danger);box-shadow:0 0 6px var(--danger)}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}.canvas-node .node-body{padding:12px 14px;font-size:12px;color:var(--text-muted);line-height:1.5}.canvas-node .node-thumb{width:100%;height:90px;background:var(--bg-3);display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--text-soft)}.canvas-node .node-meta{padding:8px 14px;font-size:11px;color:var(--text-soft);border-top:1px solid var(--border);background:var(--bg-1);display:flex;justify-content:space-between}.node-panel{position:absolute;top:16px;right:16px;bottom:70px;width:360px;background:var(--bg-1);border:1px solid var(--border-2);border-radius:14px;z-index:20;overflow-y:auto;backdrop-filter:blur(20px);box-shadow:var(--shadow-lg)}.node-panel-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;position:sticky;top:0;background:var(--bg-1);z-index:1}.node-panel-body{padding:18px 20px}.shot-row{background:var(--bg-1);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:10px;display:grid;grid-template-columns:60px 1fr 200px 160px;gap:16px;align-items:start;transition:border-color .15s}.shot-row:hover{border-color:var(--border-2)}.shot-row .shot-num{width:48px;height:48px;border-radius:10px;background:var(--glass-2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;letter-spacing:-.01em}.prompt-source-toggle{display:inline-flex;background:var(--bg-2);border:1px solid var(--border);border-radius:7px;padding:2px;gap:1px;margin-bottom:8px}.prompt-source-toggle .source-item{padding:4px 10px;border-radius:5px;font-size:11px;color:var(--text-muted);cursor:pointer}.prompt-source-toggle .source-item.active{background:var(--bg-4);color:var(--text)}.shot-thumb-grid{display:flex;gap:4px}.shot-thumb-grid .mini-thumb{width:60px;height:60px;border-radius:6px;background:var(--bg-3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-soft);font-size:14px}.character-card{background:var(--bg-1);border:1px solid var(--border);border-radius:14px;padding:20px;margin-bottom:16px}.character-card .char-header{display:flex;align-items:center;gap:14px;margin-bottom:14px}.character-card .char-avatar{width:56px;height:56px;border-radius:12px;background:var(--bg-3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.character-card .char-name{font-weight:600;font-size:15px;letter-spacing:-.01em;margin-bottom:3px}.character-card .char-desc{font-size:12px;color:var(--text-muted)}.character-card .char-images{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}.character-card .char-img{aspect-ratio:1;border-radius:8px;background:var(--bg-3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-soft);cursor:pointer;position:relative;overflow:hidden}.character-card .char-img.add{border-style:dashed;font-size:20px}.character-card .char-img.add:hover{border-color:#a855f780;color:#c4b5fd}.video-preview{position:relative;border-radius:12px;overflow:hidden;background:var(--bg-3);aspect-ratio:16/9}.video-preview.vertical{aspect-ratio:9/16}.video-preview .play-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0000004d;color:#fff;font-size:36px;cursor:pointer;transition:background .15s}.video-preview .play-overlay:hover{background:#00000080}.video-preview .video-meta{position:absolute;bottom:8px;left:8px;right:8px;display:flex;justify-content:space-between;font-size:11px;color:#ffffffe6}.gen-history-strip{display:flex;gap:8px;overflow-x:auto;padding:4px 0}.gen-history-strip .history-item{flex-shrink:0;width:120px;border-radius:8px;border:1px solid var(--border);overflow:hidden;cursor:pointer;transition:border-color .15s}.gen-history-strip .history-item.selected{border-color:#a855f799;box-shadow:0 0 0 2px #a855f733}.gen-history-strip .history-thumb{aspect-ratio:16/9;background:var(--bg-3);display:flex;align-items:center;justify-content:center;color:var(--text-soft)}.gen-history-strip .history-meta{padding:6px 8px;font-size:11px;color:var(--text-muted)}
