@import"https://fonts.googleapis.com/css2?family=Fredoka:wght@400;500;600;700&family=Noto+Sans+TC:wght@300;400;500;700&family=Noto+Serif+TC:wght@400;500;600;700&display=swap";.canvas-page{position:fixed;top:0;left:0;right:0;bottom:0;z-index:100;background:#141414;overflow:hidden;display:flex}.canvas-back-btn{position:fixed;top:16px;left:16px;z-index:300;display:flex;align-items:center;gap:6px;padding:8px 14px;background:#1e1e1ed9;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fffc;font-size:13px;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .15s ease}.canvas-back-btn:hover{background:#323232e6;color:#fff}.canvas-viewport{flex:1;position:relative;overflow:hidden;background-color:#141414;background-image:radial-gradient(circle,rgba(255,255,255,.2) 1px,transparent 1px);background-size:28px 28px}.canvas-viewport-inner{position:absolute;top:0;left:0;width:0;height:0;will-change:transform}.canvas-node{position:absolute;border-radius:8px;background:transparent;border:2px solid transparent;overflow:visible;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none;will-change:transform;cursor:grab}.canvas-node img,.canvas-node video,.canvas-node audio{-webkit-user-drag:none;user-drag:none;pointer-events:auto}.canvas-node.dragging{cursor:grabbing;opacity:.85;z-index:10}.canvas-node.selected{border-color:var(--primary)}.canvas-node.batch-highlight{border-color:#6366f18c;box-shadow:0 0 0 2px #6366f159}.canvas-node-drag-handle{position:absolute;top:0;left:0;right:0;height:24px;z-index:1;pointer-events:none}.node-content{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px;box-sizing:border-box;overflow:hidden;border-radius:6px}.node-content.placeholder{color:#fff6;gap:8px;cursor:pointer;font-size:12px;background:#ffffff08;border:1px dashed rgba(255,255,255,.15);border-radius:8px}.node-content.placeholder:hover{color:#ffffffb3;background:#ffffff0f;border-color:#ffffff4d}.node-content-text{padding:0;background:#1e1e1ed9;border:1px solid rgba(255,255,255,.1);border-radius:8px}.node-textarea{width:100%;height:100%;border:none;background:transparent;color:#ffffffe6;font-size:14px;line-height:1.5;padding:12px;resize:none;outline:none;font-family:inherit;box-sizing:border-box}.node-textarea::-moz-placeholder{color:#ffffff4d}.node-textarea::placeholder{color:#ffffff4d}.node-content-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:4px}.node-content-video{position:relative}.node-content-video video{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;border-radius:4px}.node-content-audio audio{width:90%}.node-content-agent{padding:0;display:flex;flex-direction:column;background:#1e1e1ed9;border:1px solid rgba(255,255,255,.1);border-radius:8px}.agent-header{display:flex;align-items:center;gap:6px;padding:8px 12px;border-bottom:1px solid var(--line);color:var(--text);font-size:13px;font-weight:500}.agent-messages{flex:1;overflow-y:auto;padding:8px;font-size:12px}.agent-msg{padding:4px 8px;border-radius:6px;margin-bottom:4px;max-width:90%}.agent-msg-user{background:var(--primary-soft);color:var(--text);margin-left:auto}.agent-msg-assistant{background:var(--bg-soft);color:var(--text-muted)}.agent-input-row{display:flex;gap:4px;padding:8px;border-top:1px solid var(--line)}.agent-input{flex:1;border:1px solid var(--line);background:var(--bg);color:var(--text);border-radius:4px;padding:4px 8px;font-size:12px;outline:none}.agent-input:focus{border-color:var(--primary)}.agent-send-btn{background:var(--primary);color:#fff;border:none;border-radius:4px;padding:4px 10px;font-size:12px;cursor:pointer}.agent-send-btn:hover{background:var(--primary-hover)}.canvas-context-menu{position:fixed;z-index:1000;background:var(--bg-elevated);border:1px solid var(--line-strong);border-radius:8px;padding:4px;min-width:180px;box-shadow:0 8px 24px #0006}.context-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;border:none;background:transparent;color:var(--text);font-size:13px;cursor:pointer;border-radius:4px;text-align:left}.context-menu-item:hover{background:var(--bg-soft)}.context-menu-item svg{flex-shrink:0;color:var(--text-muted)}.context-menu-divider{height:1px;background:var(--line);margin:4px 8px}.canvas-left-toolbar{position:fixed;left:16px;top:50%;transform:translateY(-50%);z-index:200;display:flex;flex-direction:column;gap:4px;padding:8px;background:var(--bg-glass);border:1px solid var(--line);border-radius:12px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.toolbar-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;color:var(--text-muted);border-radius:8px;cursor:pointer;transition:all .15s ease}.toolbar-btn:hover{background:var(--bg-soft);color:var(--text)}.toolbar-btn.active{background:var(--primary);color:#fff}.canvas-controls{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:200;display:flex;align-items:center;gap:4px;padding:6px 12px;background:var(--bg-glass);border:1px solid var(--line);border-radius:24px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.control-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--text-muted);border-radius:6px;cursor:pointer;transition:all .15s ease}.control-btn:hover{background:var(--bg-soft);color:var(--text)}.zoom-display{color:var(--text);font-size:12px;font-weight:500;min-width:40px;text-align:center;-webkit-user-select:none;-moz-user-select:none;user-select:none}.control-divider{width:1px;height:20px;background:var(--line);margin:0 4px}.chat-toggle-btn{position:fixed;right:16px;top:50%;transform:translateY(-50%);z-index:200;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-glass);border:1px solid var(--line);border-radius:50%;color:var(--text-muted);cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .15s ease}.chat-toggle-btn:hover{color:var(--text);background:var(--bg-soft)}.chat-toggle-btn.expanded{right:316px}.canvas-chat-panel{position:fixed;right:0;top:0;bottom:0;width:300px;z-index:190;background:var(--bg-elevated);border-left:1px solid var(--line);display:flex;flex-direction:column}.chat-panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--line)}.chat-panel-title{color:var(--text);font-size:14px;font-weight:600}.chat-collapse-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;color:var(--text-muted);border-radius:6px;cursor:pointer}.chat-collapse-btn:hover{background:var(--bg-soft);color:var(--text)}.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px}.chat-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-subtle);font-size:13px}.chat-msg{padding:8px 12px;border-radius:8px;font-size:13px;line-height:1.5;max-width:85%;word-break:break-word}.chat-msg-user{background:var(--primary-soft);color:var(--text);align-self:flex-end}.chat-msg-assistant{background:var(--bg-soft);color:var(--text-muted);align-self:flex-start}.chat-input-row{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--line)}.chat-input{flex:1;border:1px solid var(--line);background:var(--bg);color:var(--text);border-radius:8px;padding:8px 12px;font-size:13px;outline:none}.chat-input:focus{border-color:var(--primary)}.chat-send-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:var(--primary);color:#fff;border-radius:8px;cursor:pointer;transition:background .15s ease}.chat-send-btn:hover{background:var(--primary-hover)}.canvas-projects-page{max-width:1280px;margin:0 auto;padding:32px 24px 80px;min-height:60vh}.canvas-projects-header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:32px;flex-wrap:wrap}.canvas-projects-header-left{flex:1;min-width:0}.canvas-projects-title{font-size:28px;font-weight:600;color:var(--text);margin:0 0 6px;letter-spacing:-.01em}.canvas-projects-subtitle{color:var(--text-muted);font-size:14px;margin:0}.canvas-projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.canvas-projects-error{text-align:center;padding:60px 20px;color:var(--text-muted);font-size:14px}.canvas-projects-error p{margin:0 0 16px}.canvas-projects-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 20px;gap:12px}.canvas-projects-empty-icon{width:96px;height:96px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--bg-soft);color:var(--text-muted);margin-bottom:8px}.canvas-projects-empty-title{font-size:18px;color:var(--text);margin:0;font-weight:600}.canvas-projects-empty-text{color:var(--text-muted);font-size:14px;margin:0 0 16px}.project-card{position:relative;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:18px 16px;border-radius:12px;background:var(--bg-elevated);border:1px solid var(--line);cursor:pointer;transition:border-color .15s ease,transform .15s ease,box-shadow .15s ease,background .15s ease;min-height:84px;overflow:hidden}.project-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 8px 24px #0000002e}.project-card-body{flex:1;min-width:0;display:flex;align-items:center;gap:12px}.project-card-icon{flex-shrink:0;width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:var(--primary-soft);color:var(--primary)}.project-card-info{flex:1;min-width:0}.project-card-name{font-size:15px;font-weight:600;color:var(--text);margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-card-meta{font-size:12px;color:var(--text-subtle);margin:0}.project-card-skeleton{position:relative;background:var(--bg-soft);cursor:default;pointer-events:none}.project-card-skeleton:hover{border-color:var(--line);transform:none;box-shadow:none}.project-card-menu{position:relative;flex-shrink:0}.project-card-menu-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;color:var(--text-muted);border-radius:6px;cursor:pointer;transition:background .15s ease,color .15s ease}.project-card-menu-btn:hover{background:var(--bg-soft);color:var(--text)}.project-card-menu-dropdown{position:absolute;top:calc(100% + 4px);right:0;min-width:120px;background:var(--bg-elevated);border:1px solid var(--line);border-radius:8px;box-shadow:0 8px 24px #0000004d;overflow:hidden;z-index:50}.project-card-menu-item{display:block;width:100%;padding:9px 14px;border:none;background:transparent;color:var(--text);font-size:13px;text-align:left;cursor:pointer;transition:background .15s ease}.project-card-menu-item:hover{background:var(--bg-soft)}.project-card-menu-item-danger{color:var(--danger, #ef4444)}.project-card-menu-item-danger:hover{background:#ef444414}.canvas-loading-spinner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:16px;color:#ffffffb3;font-size:13px}.canvas-loading-spinner-ring{width:36px;height:36px;border-radius:50%;border:3px solid rgba(255,255,255,.1);border-top-color:#fffc;animation:canvas-spin .9s linear infinite}@keyframes canvas-spin{to{transform:rotate(360deg)}}.canvas-project-name{position:fixed;top:18px;left:50%;transform:translate(-50%);z-index:250;padding:6px 16px;background:#1e1e1ed9;border:1px solid rgba(255,255,255,.08);border-radius:8px;color:#ffffffd9;font-size:13px;font-weight:500;max-width:360px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:none}.canvas-save-indicator{position:fixed;top:16px;right:16px;z-index:300;display:flex;align-items:center;gap:8px;padding:8px 12px;background:#1e1e1ed9;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#ffffffd9;font-size:12px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:opacity .3s ease;pointer-events:auto}.canvas-save-indicator-saving{color:#ffffffb3}.canvas-save-indicator-saved{color:#4ade80;border-color:#4ade8040}.canvas-save-indicator-error{color:#f87171;border-color:#f871714d}.canvas-save-indicator-spinner svg{animation:canvas-spin .9s linear infinite}.canvas-save-indicator-retry{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border:none;background:transparent;color:inherit;border-radius:4px;cursor:pointer;margin-left:2px;transition:background .15s ease}.canvas-save-indicator-retry:hover{background:#ffffff14}.project-card-skeleton .skeleton-shimmer{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.04) 50%,transparent 100%);animation:project-shimmer 1.4s ease-in-out infinite}@keyframes project-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.connection-handle{position:absolute;right:-20px;top:50%;transform:translateY(-50%);width:28px;height:28px;border-radius:50%;border:2px solid rgba(255,255,255,.3);background:#141414e6;display:flex;align-items:center;justify-content:center;cursor:crosshair;opacity:0;transition:opacity .2s,border-color .2s;z-index:5}.canvas-node:hover .connection-handle{opacity:1}.connection-handle:hover{border-color:var(--primary);background:#6366f133}.connection-handle svg{color:#ffffffb3}.connection-handle:hover svg{color:var(--primary)}.is-connection-dragging .connection-handle{opacity:0!important;pointer-events:none}.connections-layer{position:absolute;top:0;left:0;width:1px;height:1px;overflow:visible;pointer-events:none}.connection-path{pointer-events:stroke;cursor:pointer;transition:stroke .2s}.connection-path:hover{stroke:#6366f1;stroke-width:3}.node-content-video-gen{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;background:#1e1e1ee6;border:1px solid rgba(255,255,255,.08);border-radius:8px}.node-content-video-gen.completed{padding:0;background:transparent;border:none;position:relative}.video-gen-panel{position:absolute;z-index:500;background:#1e1e1ef2;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:16px;width:400px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 12px 40px #00000080}.video-gen-panel-tabs{display:flex;gap:4px;margin-bottom:12px}.video-gen-panel-tab{padding:6px 12px;border:1px solid rgba(255,255,255,.15);border-radius:6px;background:transparent;color:#fff9;font-size:12px;cursor:pointer;transition:all .15s}.video-gen-panel-tab.active{background:#ffffff1a;color:#fff;border-color:#ffffff4d}.video-gen-panel-slots{display:flex;gap:8px;margin-bottom:12px}.video-gen-panel-slot{width:60px;height:60px;border:1px dashed rgba(255,255,255,.2);border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;transition:border-color .15s}.video-gen-panel-slot:hover{border-color:#fff6}.video-gen-panel-slot img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.video-gen-panel-slot svg{color:#ffffff4d}.video-gen-panel-prompt{width:100%;min-height:60px;padding:10px 12px;border:1px solid rgba(255,255,255,.1);border-radius:8px;background:#0000004d;color:#ffffffe6;font-size:13px;resize:none;outline:none;margin-bottom:12px;font-family:inherit;box-sizing:border-box}.video-gen-panel-prompt::-moz-placeholder{color:#ffffff4d}.video-gen-panel-prompt::placeholder{color:#ffffff4d}.video-gen-panel-prompt:focus{border-color:#6366f180}.video-gen-panel-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.video-gen-panel-controls select{padding:6px 10px;border:1px solid rgba(255,255,255,.1);border-radius:6px;background:#0000004d;color:#fffc;font-size:12px;outline:none}.video-gen-panel-credits{display:flex;align-items:center;gap:4px;font-size:12px;color:#ffffff80;margin-left:auto}.video-gen-panel-credits svg{color:#f59e0b}.video-gen-panel-credits .video-gen-panel-submit{margin-left:8px}.video-gen-panel-submit{width:32px;height:32px;border-radius:50%;border:none;background:#fff;color:#141414;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .15s}.video-gen-panel-submit:hover{transform:scale(1.1)}.video-gen-panel-submit:disabled{opacity:.4;cursor:not-allowed;transform:none}.video-gen-panel-toggle{display:flex;align-items:center;gap:4px;font-size:11px;color:#fff9;cursor:pointer;white-space:nowrap}.video-gen-panel-toggle input[type=checkbox]{width:14px;height:14px;accent-color:var(--primary);cursor:pointer}.node-content-image-gen{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;background:#1e1e1ee6;border:1px solid rgba(255,255,255,.08);border-radius:8px}.node-content-image-gen.completed{padding:0;background:transparent;border:none}.gen-progress-ring{position:relative;display:flex;align-items:center;justify-content:center}.gen-progress-text{position:absolute;font-size:11px;font-weight:600;color:#fffc}.image-gen-size-trigger{display:flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid rgba(255,255,255,.15);border-radius:6px;background:#0000004d;color:#fffc;font-size:12px;cursor:pointer;transition:border-color .15s,background .15s}.image-gen-size-trigger:hover{border-color:#ffffff4d;background:#0006}.image-gen-size-trigger svg{flex-shrink:0}.image-gen-size-popup{position:absolute;bottom:calc(100% + 8px);left:16px;right:16px;background:#191919fa;border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:14px;box-shadow:0 12px 40px #0009;z-index:10}.image-gen-size-section{margin-bottom:12px}.image-gen-size-section:last-child{margin-bottom:0}.image-gen-size-label{display:block;font-size:11px;color:#ffffff80;margin-bottom:8px;font-weight:500}.image-gen-ratio-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.image-gen-ratio-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;border:1px solid rgba(255,255,255,.1);border-radius:6px;background:transparent;color:#fff9;font-size:10px;cursor:pointer;transition:all .15s}.image-gen-ratio-btn:hover{border-color:#ffffff40;color:#ffffffe6;background:#ffffff0d}.image-gen-ratio-btn.active{border-color:var(--primary);color:#fff;background:#6366f126}.image-gen-ratio-btn svg{flex-shrink:0}.image-gen-resolution-bar{display:flex;gap:4px;background:#0000004d;border-radius:6px;padding:3px}.image-gen-resolution-btn{flex:1;padding:6px 12px;border:none;border-radius:4px;background:transparent;color:#ffffff80;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s}.image-gen-resolution-btn:hover{color:#fffc}.image-gen-resolution-btn.active{background:#ffffff1f;color:#fff}.image-gen-inline-select{display:flex;gap:2px;background:#0000004d;border-radius:6px;padding:2px}.image-gen-inline-btn{padding:4px 8px;border:none;border-radius:4px;background:transparent;color:#ffffff80;font-size:11px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.image-gen-inline-btn:hover{color:#fffc}.image-gen-inline-btn.active{background:#ffffff1f;color:#fff}.image-gen-enhance-section{margin-bottom:12px;border:1px solid rgba(255,255,255,.08);border-radius:8px;overflow:hidden}.image-gen-enhance-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;cursor:pointer;transition:background .15s}.image-gen-enhance-header:hover{background:#ffffff08}.image-gen-enhance-title{display:flex;align-items:center;gap:6px;font-size:12px;color:#ffffffb3}.image-gen-enhance-title svg{color:#f59e0b}.image-gen-enhance-chevron{transition:transform .2s;color:#fff6}.image-gen-enhance-chevron.open{transform:rotate(180deg)}.image-gen-enhance-tags{display:flex;flex-wrap:wrap;gap:4px;padding:0 10px 8px}.image-gen-enhance-tag{display:flex;align-items:center;gap:4px;padding:3px 8px;background:#6366f126;border:1px solid rgba(99,102,241,.3);border-radius:4px;color:#fffc;font-size:10px;cursor:pointer;transition:all .15s}.image-gen-enhance-tag:hover{background:#ef444426;border-color:#ef44444d}.image-gen-enhance-tag svg{opacity:.6}.image-gen-enhance-panel{max-height:200px;overflow-y:auto;padding:8px 10px;border-top:1px solid rgba(255,255,255,.06)}.image-gen-enhance-category{margin-bottom:8px}.image-gen-enhance-category:last-child{margin-bottom:0}.image-gen-enhance-cat-title{display:block;font-size:10px;color:#fff6;margin-bottom:4px;font-weight:500}.image-gen-enhance-list{display:flex;flex-wrap:wrap;gap:4px}.image-gen-enhance-item{padding:3px 8px;border:1px solid rgba(255,255,255,.1);border-radius:4px;background:transparent;color:#fff9;font-size:10px;cursor:pointer;transition:all .15s}.image-gen-enhance-item:hover{border-color:#ffffff40;color:#ffffffe6;background:#ffffff0d}.image-gen-enhance-item.active{border-color:var(--primary);color:#fff;background:#6366f126}.image-gen-references{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.image-gen-reference-item{position:relative;width:60px;height:60px;border-radius:8px;overflow:hidden;border:1px solid rgba(255,255,255,.15);flex-shrink:0}.image-gen-reference-item img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.image-gen-reference-remove{position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:50%;border:none;background:#000000b3;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:background .15s}.image-gen-reference-remove:hover{background:#ef4444e6}.image-gen-reference-add{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;width:60px;height:60px;border-radius:8px;border:1px dashed rgba(255,255,255,.2);background:transparent;color:#ffffff80;font-size:10px;cursor:pointer;transition:all .15s;flex-shrink:0}.image-gen-reference-add:hover:not(:disabled){border-color:#fff6;color:#fffc;background:#ffffff08}.image-gen-reference-add:disabled{opacity:.5;cursor:not-allowed}.image-lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;z-index:10000;display:flex;align-items:center;justify-content:center;cursor:zoom-out;animation:lightbox-fade-in .18s ease-out}@keyframes lightbox-fade-in{0%{opacity:0}to{opacity:1}}.image-lightbox-figure{position:relative;display:inline-block;max-width:95vw;max-height:95vh;line-height:0}.image-lightbox-img{display:block;max-width:95vw;max-height:95vh;-o-object-fit:contain;object-fit:contain;cursor:default;border-radius:6px;box-shadow:0 20px 60px #00000080}.image-lightbox-close{position:absolute;top:8px;right:8px;width:36px;height:36px;border-radius:50%;border:none;background:#0000008c;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,transform .15s;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1}.image-lightbox-close:hover{background:#000000bf;transform:scale(1.05)}.node-video-hint{position:absolute;bottom:8px;left:50%;transform:translate(-50%);padding:4px 10px;background:#0009;color:#ffffffe6;font-size:11px;border-radius:4px;pointer-events:none}.node-video-exit{position:absolute;top:6px;right:6px;width:24px;height:24px;border-radius:50%;border:none;background:#000000b3;color:#fff;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:5;line-height:1}.node-video-exit:hover{background:#ef4444e6}.canvas-drag-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:400;background:#6366f126;border:3px dashed rgba(99,102,241,.6);display:flex;align-items:center;justify-content:center;pointer-events:none;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.canvas-drag-overlay-inner{display:flex;flex-direction:column;align-items:center;gap:12px;padding:32px 48px;background:#1e1e1eeb;border-radius:16px;color:#fffffff2;font-size:16px;font-weight:500;box-shadow:0 12px 40px #00000080}.canvas-drag-overlay-inner svg{color:#6366f1f2}.canvas-drag-overlay-inner p{margin:0}.node-content-image-uploading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;width:100%;height:100%;background:#1e1e1ed9;border:1px dashed rgba(99,102,241,.4);border-radius:8px;color:#ffffffd9}.node-upload-progress-ring{position:relative;display:flex;align-items:center;justify-content:center}.node-upload-progress-text{position:absolute;font-size:11px;font-weight:600;color:#fffffff2}.node-upload-label{font-size:11px;color:#fff9}*,: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: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.\!visible{visibility:visible!important}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.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))}.resize{resize:both}.text-ellipsis{text-overflow:ellipsis}.border{border-width:1px}.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}:root{--primary: #10b981;--primary-hover: #059669;--primary-soft: rgba(16, 185, 129, .12);--primary-glow: rgba(16, 185, 129, .4);--cta: #6366f1;--cta-hover: #4f46e5;--cta-soft: rgba(99, 102, 241, .12);--bg: #09090b;--bg-elevated: #18181b;--bg-soft: #27272a;--bg-glass: rgba(24, 24, 27, .85);--bg-card: #1f1f23;--text: #fafafa;--text-muted: #a1a1aa;--text-subtle: #71717a;--line: rgba(255, 255, 255, .06);--line-strong: rgba(255, 255, 255, .12);--success: #22c55e;--success-soft: rgba(34, 197, 94, .12);--danger: #ef4444;--danger-soft: rgba(239, 68, 68, .12);--warning: #f59e0b;--warning-soft: rgba(245, 158, 11, .12);--gradient-start: #10b981;--gradient-end: #6366f1;--orb-1: rgba(16, 185, 129, .08);--orb-2: rgba(99, 102, 241, .06);--orb-3: rgba(16, 185, 129, .04)}[data-theme=light]{--bg: #fafafa;--bg-elevated: #ffffff;--bg-soft: #f4f4f5;--bg-glass: rgba(255, 255, 255, .9);--bg-card: #ffffff;--text: #18181b;--text-muted: #71717a;--text-subtle: #a1a1aa;--line: rgba(0, 0, 0, .06);--line-strong: rgba(0, 0, 0, .1);--primary: #10b981;--primary-hover: #059669;--primary-soft: rgba(16, 185, 129, .08);--primary-glow: rgba(16, 185, 129, .15);--cta: #6366f1;--cta-hover: #4f46e5;--cta-soft: rgba(99, 102, 241, .08);--orb-1: rgba(16, 185, 129, .04);--orb-2: rgba(99, 102, 241, .03);--orb-3: rgba(16, 185, 129, .02)}*{margin:0;padding:0;box-sizing:border-box}html{font-family:Noto Sans SC,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{background:var(--bg);color:var(--text);min-height:100vh;line-height:1.6;overflow-x:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-subtle)}.app{display:flex;flex-direction:column;min-height:100vh;position:relative}.main-content{flex:1}.bg-orbs{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:0;overflow:hidden}.bg-orb{position:absolute;border-radius:50%;filter:blur(100px);animation:float 25s ease-in-out infinite}.bg-orb-1{width:700px;height:700px;background:var(--orb-1);top:-250px;right:-150px;animation-delay:0s}.bg-orb-2{width:600px;height:600px;background:var(--orb-2);bottom:-200px;left:-100px;animation-delay:-8s}.bg-orb-3{width:500px;height:500px;background:var(--orb-3);top:40%;left:60%;transform:translate(-50%,-50%);animation-delay:-16s}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(40px,-40px) scale(1.08)}66%{transform:translate(-30px,30px) scale(.95)}}.header{position:sticky;top:0;z-index:100;background:var(--bg-glass);border-bottom:1px solid var(--line);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%)}.header-inner{max-width:1400px;margin:0 auto;padding:0 24px;height:68px;display:flex;align-items:center;justify-content:space-between;gap:32px}.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--text);transition:all .2s}.brand:hover{opacity:.85;transform:scale(1.02)}.brand-logo{width:38px;height:38px;color:var(--primary);filter:drop-shadow(0 0 16px var(--primary-glow));transition:transform .3s ease}.brand:hover .brand-logo{transform:rotate(15deg)}.brand-text{display:flex;flex-direction:column}.brand-name{font-family:"Noto Serif SC",Fredoka,sans-serif;font-size:16px;font-weight:600;line-height:1.2;letter-spacing:-.01em}.brand-tag{font-size:11px;color:var(--text-muted);font-weight:500}.nav{display:flex;gap:4px;align-items:center}.nav-link{padding:8px 16px;border-radius:10px;text-decoration:none;color:var(--text-muted);font-size:14px;font-weight:500;transition:all .2s;position:relative}.nav-link:hover{color:var(--text);background:var(--bg-soft)}.nav-link.active{color:var(--primary);background:var(--primary-soft)}.nav-link.active:after{content:"";position:absolute;bottom:4px;left:50%;transform:translate(-50%);width:16px;height:2px;background:var(--primary);border-radius:1px}.header-actions{display:flex;align-items:center;gap:12px}.mobile-menu-btn{display:none;width:36px;height:36px;border:1px solid var(--line);border-radius:10px;background:var(--bg-soft);color:var(--text);cursor:pointer;align-items:center;justify-content:center}.mobile-menu-btn svg{width:18px;height:18px}.top-logo{width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;border-radius:14px;background:var(--bg-glass);border:1px solid var(--line);box-shadow:0 10px 24px #00000014;transition:all .25s ease;text-decoration:none;overflow:hidden}.top-logo-left{margin-right:16px}.top-logo:hover{transform:translateY(-2px) rotate(-3deg);border-color:var(--line-strong);box-shadow:0 14px 32px var(--primary-glow)}.top-logo img{width:38px;height:38px}.credits-chip{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--bg-soft);border:1px solid var(--line);border-radius:24px;font-size:13px;font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.credits-chip svg{width:16px;height:16px;color:var(--primary)}.credits-chip strong{color:var(--primary);font-weight:700}.icon-btn{width:40px;height:40px;border:1px solid var(--line);border-radius:12px;background:var(--bg-soft);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .25s cubic-bezier(.4,0,.2,1)}.icon-btn:hover{color:var(--text);background:var(--bg-elevated);border-color:var(--line-strong);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.icon-btn svg{width:20px;height:20px}.theme-toggle{width:40px;height:40px;border:1px solid var(--line);border-radius:12px;background:var(--bg-soft);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .25s cubic-bezier(.4,0,.2,1);flex-shrink:0}.theme-toggle:hover{color:var(--text);background:var(--bg-elevated);border-color:var(--line-strong);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.theme-toggle svg{width:20px;height:20px}.btn{padding:10px 20px;border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:all .25s cubic-bezier(.4,0,.2,1);text-decoration:none}.btn-primary{background:linear-gradient(135deg,var(--gradient-start),var(--gradient-end));color:#fff;box-shadow:0 4px 20px var(--primary-glow),0 0 0 1px #ffffff1a}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px var(--primary-glow),0 0 0 1px #fff3;filter:brightness(1.1)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-soft);border:1px solid var(--line);color:var(--text)}.btn-secondary:hover{border-color:var(--line-strong);background:var(--bg-elevated);transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid transparent}.btn-ghost:hover{color:var(--primary);background:var(--primary-soft)}.btn-large{padding:14px 32px;font-size:15px}.profile-menu{position:relative}.user-chip{display:flex;align-items:center;gap:10px;padding:6px 12px 6px 6px;background:var(--bg-soft);border:1px solid var(--line);border-radius:28px;cursor:pointer;transition:all .2s}.user-chip:hover,.profile-menu:hover .user-chip{border-color:var(--line-strong);background:var(--bg-elevated)}.user-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--gradient-start),var(--gradient-end));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.user-info{display:flex;flex-direction:column;gap:2px}.user-email{font-size:13px;font-weight:500;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-credits{font-size:11px;color:var(--primary);font-weight:700;display:flex;align-items:center;gap:3px}.user-credits svg{width:11px;height:11px}.user-chevron{width:14px;height:14px;color:var(--text-muted);transition:transform .2s ease}.profile-menu:hover .user-chevron{transform:rotate(180deg)}.profile-dropdown{position:absolute;top:calc(100% + 10px);right:0;min-width:180px;padding:8px;border-radius:16px;background:var(--bg-glass);border:1px solid var(--line);box-shadow:0 18px 48px #00000029;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);opacity:0;transform:translateY(-6px) scale(.98);pointer-events:none;transition:all .2s ease;z-index:1000}.profile-menu:hover .profile-dropdown,.profile-menu.open .profile-dropdown{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.profile-dropdown:before{content:"";position:absolute;left:0;right:0;top:-10px;height:10px}.profile-dropdown-item{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;border:none;border-radius:12px;background:transparent;color:var(--text);text-decoration:none;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.profile-dropdown-item:hover{background:var(--bg-soft);color:var(--primary)}.profile-dropdown-item.danger:hover{color:var(--danger);background:var(--danger-soft)}.profile-dropdown-item svg{width:16px;height:16px}.home{max-width:1200px;margin:0 auto;padding:60px 24px 100px;position:relative;z-index:1}.hero{text-align:center;padding:80px 0 100px;position:relative}.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:var(--primary-soft);color:var(--primary);border:1px solid var(--primary);border-radius:100px;font-size:13px;font-weight:600;margin-bottom:32px;animation:pulse-glow 3s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px var(--primary-soft)}50%{box-shadow:0 0 40px var(--primary-glow)}}.hero-title{font-family:Noto Sans SC,-apple-system,sans-serif;font-size:clamp(32px,6vw,56px);font-weight:600;line-height:1.2;margin-bottom:24px;letter-spacing:-.02em}.hero-title-typewriter{background:linear-gradient(135deg,var(--text),var(--primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-cursor{display:inline-block;animation:blink 1s infinite;color:var(--primary);-webkit-text-fill-color:var(--primary)}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.hero-subtitle{font-size:18px;color:var(--text-muted);max-width:480px;margin:0 auto;line-height:1.7}.composer{background:var(--bg-glass);border:1px solid var(--line);border-radius:22px;padding:20px;margin-bottom:48px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 8px 40px #0003,inset 0 1px 0 var(--line);transition:border-color .3s,box-shadow .3s}.composer:focus-within{border-color:var(--primary);box-shadow:0 8px 40px #0003,0 0 0 2px var(--primary-soft)}.mode-switch{display:flex;gap:4px;background:var(--bg-secondary);border-radius:12px;padding:4px;margin-bottom:16px;width:auto}.mode-switch-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 20px;border:none;border-radius:10px;background:transparent;color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;transition:background .2s,color .2s,box-shadow .2s;white-space:nowrap;box-sizing:border-box}.mode-switch-btn svg{flex-shrink:0;width:16px;height:16px}.mode-switch-btn:hover{color:var(--text)}.mode-switch-btn.active{background:var(--primary);color:#fff;box-shadow:0 2px 8px #6366f14d}.aspect-ratio-btns{display:flex;gap:4px}.aspect-btn{padding:6px 12px;border:1px solid var(--line);border-radius:8px;background:var(--bg-secondary);color:var(--text-muted);font-size:12px;cursor:pointer;transition:all .2s}.aspect-btn:hover{border-color:var(--primary);color:var(--text)}.aspect-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.toggle-label{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted);cursor:pointer}.toggle-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary)}.video-upload-area{display:flex;gap:12px;margin-top:14px;padding-top:14px;border-top:1px solid var(--line);flex-wrap:wrap}.video-upload-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;width:100px;height:100px;border:1px dashed var(--line-strong);border-radius:12px;background:var(--bg);color:var(--text-muted);cursor:pointer;transition:all .2s}.video-upload-item:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-soft)}.video-upload-item svg{opacity:.7}.video-upload-item:hover svg{opacity:1}.video-upload-item span{font-size:11px;font-weight:500}.video-upload-item.has-image{border-style:solid;border-color:var(--primary);padding:0;position:relative;overflow:hidden}.video-upload-remove{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:50%;border:none;background:#000000b3;color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.video-upload-item.has-image:hover .video-upload-remove{opacity:1}.video-upload-count{position:absolute;bottom:4px;right:4px;padding:2px 6px;background:#000000b3;color:#fff;font-size:10px;border-radius:8px}.composer-template-badge{display:flex;align-items:center;gap:6px;padding:8px 14px;margin:12px 14px 0;background:var(--primary-soft);border-radius:8px;font-size:13px;font-weight:500;color:var(--primary)}.composer-template-badge button{margin-left:auto;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;border-radius:4px;display:flex}.composer-template-badge button:hover{color:var(--danger)}.composer-prompt{width:100%;min-height:90px;padding:14px;border:1px solid var(--line);border-radius:16px;background:var(--bg);color:var(--text);font-size:15px;line-height:1.6;resize:none;transition:all .2s;font-family:inherit}.composer-prompt:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.composer-prompt::-moz-placeholder{color:var(--text-subtle)}.composer-prompt::placeholder{color:var(--text-subtle)}.composer-controls{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}.control-group{display:flex;align-items:center;gap:10px}.control-label{font-size:13px;color:var(--text-muted);white-space:nowrap;font-weight:500}.control-select{padding:10px 14px;border:1px solid var(--line);border-radius:10px;background:var(--bg);color:var(--text);font-size:13px;cursor:pointer;transition:all .2s;min-width:90px}.control-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.template-section{margin-top:14px;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--bg-soft)}.template-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;cursor:pointer;transition:background .2s}.template-header:hover{background:var(--bg-secondary)}.template-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--text)}.template-title svg{color:var(--primary)}.template-active-label{color:var(--primary);font-weight:600;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.template-header-right{display:flex;align-items:center;gap:10px}.template-count{font-size:12px;color:var(--primary);background:var(--primary-light);padding:2px 8px;border-radius:10px}.template-chevron{transition:transform .2s;color:var(--text-muted)}.template-chevron.open{transform:rotate(180deg)}.template-tags{display:flex;flex-wrap:wrap;gap:6px;padding:0 14px 12px}.template-tag{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:var(--primary);color:#fff;font-size:12px;border-radius:14px;cursor:pointer;transition:all .2s}.template-tag:hover{background:var(--primary-dark)}.template-tag svg{opacity:.7}.template-tag:hover svg{opacity:1}.template-selector{border-top:1px solid var(--line);max-height:320px;overflow-y:auto;padding:14px;background:var(--bg)}.template-category{margin-bottom:16px}.template-category:last-child{margin-bottom:0}.template-category-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text);margin-bottom:10px}.template-list{display:flex;flex-wrap:wrap;gap:8px}.template-item{padding:6px 12px;border:1px solid var(--border);border-radius:8px;background:var(--bg-secondary);color:var(--text);font-size:12px;cursor:pointer;transition:all .2s}.template-item:hover{border-color:var(--primary);background:var(--bg)}.template-item.active{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}.template-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--line)}.template-section-header h4{font-size:13px;font-weight:600;color:var(--text);margin:0}.template-section-header span{font-size:12px;color:var(--text-muted)}.template-skill-categories{display:flex;flex-direction:column;gap:16px;margin-bottom:16px}.template-skill-category{background:var(--bg-secondary);border-radius:10px;padding:12px}.template-skill-category-title{font-size:12px;font-weight:600;color:var(--primary);margin:0 0 10px;text-transform:uppercase;letter-spacing:.5px}.template-skill-list{display:flex;flex-wrap:wrap;gap:6px}.template-skill-item{padding:6px 12px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-size:12px;cursor:pointer;transition:all .2s;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.template-skill-item:hover{border-color:var(--primary);background:var(--bg)}.template-skill-item.active{border-color:var(--primary);background:var(--primary);color:#fff}.template-tag-skill{background:linear-gradient(135deg,var(--primary) 0%,#8b5cf6 100%)}.template-style-categories{display:flex;flex-direction:column;gap:12px}.icon-select{position:relative;z-index:50}.icon-select-trigger{display:flex;align-items:center;gap:8px;padding:8px 12px 8px 38px;border:1px solid var(--line);border-radius:10px;background:var(--bg);color:var(--text);font-size:13px;cursor:pointer;transition:all .2s;position:relative;min-width:110px}.icon-select-trigger:hover{border-color:var(--primary)}.icon-select-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:18px;height:18px;display:flex;align-items:center;justify-content:center}.icon-select-icon svg{width:18px;height:18px}.icon-select-label{flex:1;text-align:left}.icon-select-chevron{width:16px;height:16px;opacity:.5;transition:transform .2s}.icon-select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg);border:1px solid var(--line);border-radius:10px;box-shadow:0 4px 16px #00000026;z-index:100;overflow:hidden}.icon-select-option{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px 10px 38px;border:none;background:var(--bg);color:var(--text);font-size:13px;cursor:pointer;transition:background .15s;text-align:left;position:relative}.icon-select-option:hover{background:var(--bg-secondary)}.icon-select-option.active{background:var(--primary-light);color:var(--primary)}.icon-select-option .icon-select-icon{left:10px;color:var(--text-muted)}.composer-footer{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-top:16px}.composer-credits{font-size:13px;color:var(--text-muted)}.send-btn{padding:12px 28px;font-size:14px}.credits-preview{display:flex;align-items:baseline;gap:4px;padding:10px 20px;background:linear-gradient(135deg,var(--primary-soft),transparent);border:1px solid var(--primary);border-radius:14px}.credits-preview-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.credits-preview-value{font-family:Fredoka,sans-serif;font-size:24px;font-weight:700;color:var(--primary);text-shadow:0 0 20px var(--primary-glow)}.credits-preview-unit{font-size:12px;color:var(--text-muted)}.reference-strip{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}.reference-item{position:relative;width:72px;height:72px;border-radius:12px;overflow:hidden;border:2px solid var(--line);transition:all .2s}.reference-item:hover{border-color:var(--primary);transform:scale(1.05)}.reference-item img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.reference-remove{position:absolute;top:-6px;right:-6px;width:20px;height:20px;border-radius:50%;border:none;background:var(--danger);color:#fff;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.reference-item:hover .reference-remove{opacity:1}.gallery-section{margin-top:80px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}.section-title{font-family:Fredoka,sans-serif;font-size:28px;font-weight:700;display:flex;align-items:center;gap:12px;letter-spacing:-.02em}.section-title svg{color:var(--primary)}.section-badge{padding:6px 14px;background:var(--primary-soft);color:var(--primary);border-radius:20px;font-size:12px;font-weight:600}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.gallery-card{position:relative;height:0;border-radius:20px;overflow:hidden;background:var(--bg-elevated);border:1px solid var(--line);transition:all .4s cubic-bezier(.4,0,.2,1);cursor:pointer}.gallery-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 24px 60px #0000004d,0 0 0 1px var(--primary-soft);border-color:var(--primary);z-index:1}.gallery-card-img{position:absolute;top:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block;transition:transform .5s ease}.gallery-card:hover .gallery-card-img{transform:scale(1.08)}.gallery-card-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(0,0,0,.92) 0%,rgba(0,0,0,.4) 40%,transparent 70%);opacity:0;transition:opacity .3s;display:flex;flex-direction:column;justify-content:flex-end;padding:20px}.gallery-card:hover .gallery-card-overlay{opacity:1}.gallery-card-prompt{color:#fff;font-size:13px;line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.gallery-card-meta{display:flex;gap:12px;margin-top:10px;font-size:11px;color:#ffffffb3}.gallery-empty{text-align:center;padding:100px 20px;position:relative}.gallery-empty-visual{position:absolute;top:0;left:50%;transform:translate(-50%);width:400px;height:300px;pointer-events:none}.gallery-empty-orb{position:absolute;width:200px;height:200px;background:var(--orb-1);border-radius:50%;filter:blur(80px);top:50%;left:30%;transform:translate(-50%,-50%);animation:float 8s ease-in-out infinite}.gallery-empty-orb-2{width:150px;height:150px;background:var(--orb-2);left:70%;animation-delay:-4s}.gallery-empty-icon{width:120px;height:120px;margin:0 auto 32px;background:linear-gradient(135deg,var(--primary-soft),var(--bg-soft));border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--line);position:relative;z-index:1}.gallery-empty-icon svg{width:52px;height:52px;color:var(--primary);filter:drop-shadow(0 0 20px var(--primary-glow))}.gallery-empty-title{font-family:Fredoka,sans-serif;font-size:26px;font-weight:700;margin-bottom:12px;position:relative;z-index:1}.gallery-empty-text{color:var(--text-muted);margin-bottom:32px;font-size:15px;position:relative;z-index:1}.history-page{max-width:1600px;margin:0 auto;padding:48px 24px 100px;position:relative;z-index:1}.history-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:40px;padding-bottom:28px;border-bottom:1px solid var(--line)}.history-type-tabs{display:flex;gap:0;margin-bottom:24px;border-bottom:1px solid var(--line)}.history-type-tab{display:inline-flex;align-items:center;gap:6px;padding:10px 24px;border:none;background:transparent;color:var(--text-muted);font-size:14px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .2s,border-color .2s;white-space:nowrap;box-sizing:border-box}.history-type-tab svg{flex-shrink:0;width:16px;height:16px}.history-type-tab:hover{color:var(--text)}.history-type-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.history-header-left{display:flex;flex-direction:column;gap:8px}.history-header-right{display:flex;align-items:center;gap:16px}.history-title{font-family:"Noto Serif SC",Fredoka,sans-serif;font-size:42px;font-weight:700;letter-spacing:-.03em;background:linear-gradient(135deg,var(--text) 0%,var(--text-muted) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.history-subtitle{color:var(--text-muted);font-size:15px}.count-badge{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--bg-soft);border:1px solid var(--line);border-radius:20px;font-size:14px;color:var(--text-muted)}.count-badge svg{color:var(--primary)}.masonry-grid{-moz-columns:4;columns:4;-moz-column-gap:20px;column-gap:20px}@media (max-width: 1400px){.masonry-grid{-moz-columns:3;columns:3}}@media (max-width: 1000px){.masonry-grid{-moz-columns:2;columns:2}}@media (max-width: 600px){.masonry-grid{-moz-columns:1;columns:1}.history-header{flex-direction:column;gap:20px}.history-header-right{width:100%;justify-content:space-between}}.history-item{-moz-column-break-inside:avoid;break-inside:avoid;margin-bottom:20px;animation:fadeSlideUp .5s cubic-bezier(.4,0,.2,1) both}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.history-card{position:relative;width:100%;border-radius:16px;overflow:hidden;background:var(--bg-elevated);border:1px solid var(--line);transition:all .4s cubic-bezier(.4,0,.2,1);cursor:pointer}.history-card:hover{transform:translateY(-6px) scale(1.02);box-shadow:0 24px 60px #00000059,0 0 0 1px var(--primary),0 0 60px var(--primary-glow);border-color:var(--primary)}.history-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;opacity:0;transition:opacity .5s ease,transform .6s ease}.history-img.loaded{opacity:1}.history-card:hover .history-img{transform:scale(1.06)}.history-skeleton{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,var(--bg-soft) 0%,var(--bg-card) 100%);overflow:hidden}.skeleton-card{position:relative;width:100%;border-radius:16px;overflow:hidden;background:var(--bg-elevated);border:1px solid var(--line)}.skeleton-shimmer{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.05) 50%,transparent 100%);background-size:200% 100%;animation:shimmer 2s infinite}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.history-error{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-soft);color:var(--text-muted);gap:12px}.history-error svg{width:48px;height:48px;opacity:.4}.history-error p{font-size:13px;color:#ef4444}.generating-state{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-soft) 0%,var(--bg-card) 100%);gap:12px;padding:20px}.generating-spinner{position:relative;width:60px;height:60px}.spinner-ring{position:absolute;top:0;right:0;bottom:0;left:0;border:3px solid transparent;border-top-color:var(--primary);border-radius:50%;animation:spin 1.2s linear infinite}.spinner-ring:nth-child(2){top:6px;right:6px;bottom:6px;left:6px;border-width:2px;animation-duration:1.5s;animation-direction:reverse}.spinner-ring:nth-child(3){top:14px;right:14px;bottom:14px;left:14px;border-width:1px;animation-duration:2s}.generating-text{font-size:14px;color:var(--primary);font-weight:500}.generating-dimensions{font-size:12px;color:var(--text-muted);text-align:center;margin-top:4px}.generating-prompt-hint{font-size:12px;color:var(--text-muted);text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-item.generating .history-overlay{opacity:1}.history-overlay{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;transition:opacity .35s ease;display:flex;flex-direction:column;justify-content:space-between;padding:16px;background:linear-gradient(180deg,#0009,#0000001a 30%,#0000001a 70%,#000c)}.history-card:hover .history-overlay{opacity:1}.overlay-gradient{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,transparent 0%,rgba(0,0,0,.3) 100%);pointer-events:none}.overlay-top{display:flex;justify-content:space-between;transform:translateY(-10px);opacity:0;transition:all .35s ease}.history-card:hover .overlay-top{transform:translateY(0);opacity:1}.overlay-credits{display:flex;align-items:center;gap:4px;padding:6px 10px;background:#000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;font-size:11px;color:#ffffffe6;font-weight:500}.overlay-credits svg{color:#f59e0b}.overlay-badge{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;font-size:11px;color:#ffffffe6;font-weight:500}.overlay-badge svg{color:var(--primary)}.overlay-bottom{transform:translateY(10px);opacity:0;transition:all .35s ease .05s}.history-card:hover .overlay-bottom{transform:translateY(0);opacity:1}.overlay-prompt{color:#fff;font-size:13px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-shadow:0 2px 8px rgba(0,0,0,.5);margin-bottom:8px}.overlay-time{font-size:11px;color:#ffffffb3}.overlay-actions{position:absolute;bottom:16px;right:16px;display:flex;gap:8px;transform:translateY(20px);opacity:0;transition:all .35s ease .1s}.history-card:hover .overlay-actions{transform:translateY(0);opacity:1}.action-btn{width:40px;height:40px;border:none;border-radius:12px;background:#fffffff2;color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .25s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 16px #0000004d}.action-btn:hover{background:var(--primary);color:#fff;transform:scale(1.1);box-shadow:0 8px 24px var(--primary-glow)}.action-btn svg{width:18px;height:18px}.history-empty{text-align:center;padding:120px 20px;position:relative}.empty-visual{position:absolute;top:0;left:50%;transform:translate(-50%);width:500px;height:400px;pointer-events:none}.empty-orb{position:absolute;border-radius:50%;filter:blur(100px)}.empty-orb-1{width:300px;height:300px;background:var(--orb-1);top:20%;left:20%;animation:float 10s ease-in-out infinite}.empty-orb-2{width:200px;height:200px;background:var(--orb-2);top:30%;right:20%;animation:float 8s ease-in-out infinite reverse}.empty-orb-3{width:150px;height:150px;background:var(--orb-3);bottom:20%;left:40%;animation:float 12s ease-in-out infinite}@keyframes float{0%,to{transform:translate(0) scale(1)}50%{transform:translate(30px,-30px) scale(1.1)}}.empty-icon{width:140px;height:140px;margin:0 auto 40px;background:linear-gradient(135deg,var(--primary-soft),var(--bg-soft));border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--line);position:relative;z-index:1;animation:pulse-icon 3s ease-in-out infinite}@keyframes pulse-icon{0%,to{box-shadow:0 0 0 0 var(--primary-soft)}50%{box-shadow:0 0 0 20px transparent}}.empty-icon svg{width:60px;height:60px;color:var(--primary);filter:drop-shadow(0 0 20px var(--primary-glow))}.empty-title,.gallery-title,.gallery-empty-title,.generating-title{font-family:"Noto Serif SC",Fredoka,sans-serif;font-size:32px;font-weight:700;margin-bottom:16px;position:relative;z-index:1}.empty-text{color:var(--text-muted);font-size:16px;margin-bottom:40px;position:relative;z-index:1}.empty-state{text-align:center;padding:100px 20px}.empty-icon{width:100px;height:100px;margin:0 auto 28px;background:linear-gradient(135deg,var(--primary-soft),var(--bg-soft));border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--line)}.empty-icon svg{width:44px;height:44px;color:var(--primary)}.empty-title,.gallery-title,.gallery-empty-title,.generating-title{font-family:"Noto Serif SC",Fredoka,sans-serif;font-size:22px;font-weight:700;margin-bottom:10px}.empty-text{color:var(--text-muted);margin-bottom:28px;font-size:15px}.generating-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .3s ease;cursor:pointer}.generating-modal{background:var(--bg-elevated);border:1px solid var(--line);border-radius:28px;padding:48px;max-width:480px;width:90%;text-align:center;animation:scaleIn .4s cubic-bezier(.4,0,.2,1);box-shadow:0 32px 80px #00000080;cursor:default}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.generating-visual{position:relative;width:200px;height:200px;margin:0 auto 36px}.generating-orbs{position:absolute;top:-20px;right:-20px;bottom:-20px;left:-20px}.generating-orb{position:absolute;border-radius:50%;animation:pulse 3s ease-in-out infinite}.generating-orb-1{width:100%;height:100%;background:linear-gradient(135deg,var(--primary-soft),transparent);animation-delay:0s}.generating-orb-2{width:70%;height:70%;top:15%;left:15%;background:linear-gradient(135deg,var(--orb-2),transparent);animation-delay:-1s}.generating-orb-3{width:40%;height:40%;top:30%;left:30%;background:linear-gradient(135deg,var(--orb-3),transparent);animation-delay:-2s}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.7}}.generating-image-container{position:absolute;top:20px;right:20px;bottom:20px;left:20px;display:flex;align-items:center;justify-content:center}.generating-image-placeholder{width:140px;height:140px;border-radius:24px;background:var(--bg-soft);border:1px solid var(--line);overflow:hidden}.generating-image-inner{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,var(--primary-soft) 50%,transparent 100%);background-size:200% 100%;animation:shimmerImage 2s infinite}@keyframes shimmerImage{0%{background-position:-200% 0}to{background-position:200% 0}}.generating-content{margin-bottom:32px}.generating-title{font-family:Fredoka,sans-serif;font-size:26px;font-weight:700;margin-bottom:12px;background:linear-gradient(135deg,var(--text),var(--primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.generating-prompt{color:var(--text-muted);font-size:14px;margin-bottom:24px;line-height:1.6}.generating-progress{display:flex;flex-direction:column;gap:10px}.generating-progress-bar{height:4px;background:var(--bg-soft);border-radius:2px;overflow:hidden}.generating-progress-fill{height:100%;background:linear-gradient(90deg,var(--gradient-start),var(--gradient-end));border-radius:2px;animation:progress 3s ease-in-out infinite}@keyframes progress{0%{width:0%}50%{width:70%}to{width:100%}}.generating-progress-text{font-size:12px;color:var(--text-subtle)}.generating-tip{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:16px;padding:10px 16px;background:var(--primary-soft);border-radius:8px;font-size:12px;color:var(--text-muted)}.generating-tip svg{color:var(--primary);flex-shrink:0}.generating-cancel{padding:12px 28px;background:var(--bg-soft);border:1px solid var(--line);border-radius:12px;color:var(--text-muted);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.generating-cancel:hover{background:var(--primary-soft);color:var(--primary);border-color:var(--primary)}.pricing-page{max-width:1200px;margin:0 auto;padding:80px 24px 100px;position:relative;z-index:1}.pricing-header{text-align:center;margin-bottom:56px}.pricing-title{font-family:Fredoka,sans-serif;font-size:48px;font-weight:700;letter-spacing:-.03em;margin-bottom:16px}.pricing-subtitle{font-size:18px;color:var(--text-muted)}.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px}.pricing-card{background:var(--bg-elevated);border:1px solid var(--line);border-radius:28px;padding:36px;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.pricing-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gradient-start),var(--gradient-end));opacity:0;transition:opacity .3s}.pricing-card:hover{transform:translateY(-8px);border-color:var(--primary);box-shadow:0 24px 60px #0003}.pricing-card:hover:before{opacity:1}.pricing-card.featured{border-color:var(--primary);background:linear-gradient(180deg,var(--primary-soft) 0%,var(--bg-elevated) 50%)}.pricing-card.featured:before{opacity:1}.pricing-title,.pricing-name,.pricing-credits{font-family:"Noto Serif SC",Fredoka,sans-serif;font-size:22px;font-weight:700;margin-bottom:10px}.pricing-desc{color:var(--text-muted);font-size:14px;margin-bottom:28px}.pricing-credits{font-family:"Noto Serif SC",Fredoka,sans-serif;font-size:56px;font-weight:800;color:var(--primary);line-height:1;text-shadow:0 0 40px var(--primary-glow)}.pricing-credits span{font-size:18px;font-weight:500;color:var(--text-muted)}.pricing-price{margin:20px 0 28px;display:flex;align-items:baseline;gap:8px}.pricing-amount{font-size:36px;font-weight:800}.pricing-amount:before{content:"¥";font-size:22px}.pricing-original{font-size:16px;color:var(--text-subtle);text-decoration:line-through}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .25s ease;padding:20px}.modal{background:var(--bg-elevated);border:1px solid var(--line);border-radius:28px;width:min(480px,100%);max-height:90vh;overflow-y:auto;animation:scaleIn .35s cubic-bezier(.4,0,.2,1);box-shadow:0 32px 80px #0006}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:28px;border-bottom:1px solid var(--line)}.modal-title,.credits-preview-value{font-family:"Noto Serif SC",Fredoka,sans-serif;font-size:20px;font-weight:700}.modal-close{width:40px;height:40px;border:1px solid var(--line);border-radius:12px;background:var(--bg-soft);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.modal-close:hover{background:var(--line);color:var(--text)}.modal-body{padding:28px}.form-field{margin-bottom:22px}.form-label{display:block;font-size:13px;font-weight:600;color:var(--text-muted);margin-bottom:10px;text-transform:uppercase;letter-spacing:.04em}.form-input{width:100%;padding:14px 18px;border:1px solid var(--line);border-radius:12px;background:var(--bg);color:var(--text);font-size:15px;transition:all .2s}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.form-error{color:var(--danger);font-size:13px;margin-top:10px;padding:10px 14px;background:var(--danger-soft);border-radius:8px}.settings-layout{display:flex;min-height:calc(100vh - 68px);gap:0}.settings-sidebar{width:240px;flex-shrink:0;padding:28px 16px;border-right:1px solid var(--line);background:var(--bg-card)}.settings-sidebar-header{display:flex;align-items:center;gap:10px;padding:8px 12px 20px;margin-bottom:12px;border-bottom:1px solid var(--line)}.settings-sidebar-logo{width:32px;height:32px}.settings-sidebar-header span{font-size:16px;font-weight:700}.settings-nav{display:flex;flex-direction:column;gap:4px}.settings-nav-item{display:flex;align-items:center;gap:10px;padding:11px 14px;border:none;border-radius:14px;background:transparent;color:var(--text-muted);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;text-align:left;width:100%}.settings-nav-item svg{width:18px;height:18px;flex-shrink:0}.settings-nav-item:hover{color:var(--text);background:var(--bg-soft)}.settings-nav-item.active{color:var(--primary);background:var(--primary-soft)}.settings-main{flex:1;padding:32px 40px 80px;min-width:0}.settings-content{max-width:780px}.settings-content-header{margin-bottom:28px}.settings-content-header h1{font-size:30px;font-weight:700;margin-bottom:6px;letter-spacing:-.02em}.settings-content-header p{color:var(--text-muted);font-size:15px}.settings-card{padding:28px;border-radius:24px;background:var(--bg-card);border:1px solid var(--line);box-shadow:0 4px 20px #0000000f}.avatar-section{display:flex;align-items:center;gap:20px;padding-bottom:20px;margin-bottom:20px;border-bottom:1px solid var(--line)}.avatar-preview{width:80px;height:80px;border-radius:20px;overflow:hidden;flex-shrink:0;background:linear-gradient(135deg,var(--gradient-start),var(--gradient-end))}.avatar-preview img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:32px;font-weight:700}.avatar-actions{display:flex;flex-direction:column;gap:8px}.avatar-actions .btn{padding:8px 16px;font-size:13px}.avatar-actions .btn svg{width:16px;height:16px}.avatar-tip{font-size:12px;color:var(--text-muted)}.settings-field{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.settings-field span{color:var(--text-muted);font-size:13px;font-weight:600}.settings-field input,.settings-field textarea{width:100%;border:1px solid var(--line);border-radius:14px;background:var(--bg-soft);color:var(--text);padding:12px 14px;outline:none;transition:all .2s}.settings-field textarea{min-height:90px;resize:vertical}.settings-field input:focus,.settings-field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.settings-error{color:var(--danger);font-size:13px;margin-bottom:12px}.dashboard-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}.stat-card{padding:22px;border-radius:22px;background:var(--bg-card);border:1px solid var(--line);box-shadow:0 4px 20px #0000000f;display:flex;align-items:flex-start;gap:14px}.stat-card.stat-balance{background:linear-gradient(135deg,var(--gradient-start),var(--gradient-end));border-color:transparent;color:#fff}.stat-card.stat-balance .stat-label,.stat-card.stat-balance .stat-unit{color:#ffffffbf}.stat-card.stat-balance .stat-value{color:#fff}.stat-icon{width:44px;height:44px;border-radius:14px;background:var(--bg-soft);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-card.stat-balance .stat-icon{background:#fff3;color:#fff}.stat-icon svg{width:22px;height:22px}.stat-label{display:block;font-size:13px;color:var(--text-muted);margin-bottom:4px}.stat-value{display:block;font-size:30px;font-weight:800;letter-spacing:-.03em;color:var(--primary);line-height:1}.stat-unit{font-size:13px;color:var(--text-muted);margin-left:4px}.dashboard-section h2{font-size:18px;font-weight:700;margin-bottom:14px}.activity-list{background:var(--bg-card);border:1px solid var(--line);border-radius:20px;overflow:hidden}.activity-empty{padding:40px;text-align:center;color:var(--text-muted)}.activity-item{display:flex;align-items:center;gap:14px;padding:16px 20px;border-bottom:1px solid var(--line)}.activity-item:last-child{border-bottom:none}.activity-icon{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.activity-icon svg{width:18px;height:18px}.activity-icon.recharge{background:var(--success-soft);color:var(--success)}.activity-icon.charge{background:var(--primary-soft);color:var(--primary)}.activity-info{flex:1;min-width:0}.activity-info strong{display:block;font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.activity-info span{font-size:12px;color:var(--text-muted)}.activity-amount{font-style:normal;font-size:15px;font-weight:800}.activity-amount.positive{color:var(--success)}.activity-amount.negative{color:var(--danger)}.record-list{display:flex;flex-direction:column;gap:10px}.record-item{display:flex;align-items:center;gap:14px;padding:16px;border-radius:16px;background:var(--bg-soft);border:1px solid var(--line)}.record-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.record-icon svg{width:18px;height:18px}.record-icon.recharge{background:var(--success-soft);color:var(--success)}.record-icon.charge{background:var(--primary-soft);color:var(--primary)}.record-info{flex:1;min-width:0}.record-info strong{display:block;font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.record-info span{font-size:12px;color:var(--text-muted)}.record-amount{font-style:normal;font-size:16px;font-weight:800}.record-amount.positive{color:var(--success)}.record-amount.negative{color:var(--danger)}.record-amount.refunded{font-style:normal;font-size:13px;color:var(--text-muted)}.record-amount.refunded s{text-decoration:line-through;margin-right:6px}.record-icon.refunded{background:var(--bg-soft);color:var(--text-muted)}.record-thumb{overflow:hidden;padding:0}.record-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:12px}.record-pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:20px;padding-top:16px;border-top:1px solid var(--line)}.record-pagination button{padding:6px 14px;border-radius:8px;border:1px solid var(--line);background:var(--bg-soft);color:var(--text);font-size:13px;cursor:pointer;transition:all .2s}.record-pagination button:hover:not(:disabled){background:var(--bg-secondary)}.record-pagination button:disabled{opacity:.4;cursor:not-allowed}.record-pagination span{font-size:13px;color:var(--text-muted)}.settings-record-empty{padding:36px;text-align:center;color:var(--text-muted);border-radius:16px;background:var(--bg-soft);border:1px dashed var(--line-strong);font-size:14px}.btn.saved{background:var(--success)}@media (max-width: 1024px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.settings-layout{flex-direction:column}.settings-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--line);padding:16px}.settings-nav{flex-direction:row;overflow-x:auto;gap:6px}.settings-nav-item{flex-shrink:0;padding:8px 14px}.settings-main{padding:24px 16px 60px}.dashboard-stats{grid-template-columns:repeat(2,1fr);gap:12px}.stat-card{padding:16px;gap:10px}.stat-value{font-size:24px}.credits-chip span,.user-email{display:none}.top-logo{width:40px;height:40px}}.site-footer{border-top:1px solid var(--line);padding:56px 24px;text-align:center;position:relative;z-index:1;background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.footer-brand{display:inline-flex;align-items:center;gap:10px;font-family:"Noto Serif SC",Fredoka,sans-serif;font-size:16px;font-weight:700;margin-bottom:14px}.footer-logo svg{width:24px;height:24px;color:var(--primary)}.site-footer p{color:var(--text-muted);font-size:14px;max-width:500px;margin:0 auto}.footer-copy{margin-top:12px;font-size:13px}.footer-icp{margin-top:8px;font-size:12px}.footer-icp a{color:var(--text-muted);text-decoration:none}.footer-icp a:hover{color:var(--primary)}.loading-spinner{width:24px;height:24px;border:2px solid var(--line);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.admin-layout{display:flex;min-height:calc(100vh - 68px)}.admin-sidebar{width:240px;flex-shrink:0;background:var(--bg-card);border-right:1px solid var(--line);padding:24px 12px;position:sticky;top:68px;height:calc(100vh - 68px);overflow-y:auto}.admin-sidebar-header{display:flex;align-items:center;gap:10px;padding:8px 12px 20px;margin-bottom:12px;border-bottom:1px solid var(--line)}.admin-sidebar-header img{width:32px;height:32px}.admin-sidebar-header span{font-size:15px;font-weight:700}.admin-nav{display:flex;flex-direction:column;gap:4px}.admin-nav-item{display:flex;align-items:center;gap:10px;padding:11px 14px;border:none;border-radius:12px;background:transparent;color:var(--text-muted);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;text-align:left;width:100%}.admin-nav-item svg{width:18px;height:18px;flex-shrink:0}.admin-nav-item:hover{color:var(--text);background:var(--bg-soft)}.admin-nav-item.active{color:var(--primary);background:var(--primary-soft)}.admin-main{flex:1;padding:32px 40px 80px;min-width:0}.admin-title{font-size:28px;font-weight:700;margin-bottom:8px}.admin-desc{color:var(--text-muted);font-size:15px;margin-bottom:28px}.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:32px}.admin-stat-card{padding:22px;border-radius:20px;background:var(--bg-card);border:1px solid var(--line);display:flex;align-items:flex-start;gap:14px;transition:all .2s}.admin-stat-card:hover{transform:translateY(-2px);border-color:var(--primary);box-shadow:0 8px 24px #00000014}.admin-stat-icon{width:44px;height:44px;border-radius:12px;background:var(--primary-soft);color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.admin-stat-icon svg{width:22px;height:22px}.admin-stat-card strong{display:block;font-size:28px;font-weight:800;letter-spacing:-.02em;color:var(--primary)}.admin-stat-card span{font-size:13px;color:var(--text-muted)}.admin-table-wrapper{background:var(--bg-card);border:1px solid var(--line);border-radius:20px;overflow:hidden}.admin-table{width:100%;border-collapse:collapse}.admin-table th,.admin-table td{padding:14px 18px;text-align:left;font-size:14px}.admin-table th{background:var(--bg-soft);font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.admin-table td{border-bottom:1px solid var(--line)}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--bg-soft)}.text-primary{color:var(--primary);font-weight:600}.text-muted{color:var(--text-muted)}.text-ellipsis{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-placeholder{padding:60px;text-align:center;color:var(--text-muted);background:var(--bg-card);border:1px dashed var(--line-strong);border-radius:20px}.admin-form{background:var(--bg-card);border:1px solid var(--line);border-radius:24px;padding:28px}.admin-form-section{margin-bottom:28px}.admin-form-section:last-of-type{margin-bottom:0}.admin-form-section h3{font-size:16px;font-weight:700;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--line)}.admin-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.admin-form-field{display:flex;flex-direction:column;gap:8px}.admin-form-field-full{grid-column:1 / -1}.admin-form-field label{font-size:13px;font-weight:600;color:var(--text-muted)}.admin-form-field input,.admin-form-field textarea{padding:12px 14px;border:1px solid var(--line);border-radius:12px;background:var(--bg-soft);color:var(--text);font-size:14px;transition:all .2s}.admin-form-field textarea{resize:vertical;min-height:80px;font-family:monospace}.admin-form-field input:focus,.admin-form-field textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.admin-form-actions{margin-top:24px;padding-top:20px;border-top:1px solid var(--line)}.admin-pricing-table{width:100%;border-collapse:collapse;margin-top:12px}.admin-pricing-table th,.admin-pricing-table td{padding:10px 12px;border:1px solid var(--line);text-align:center;font-size:13px}.admin-pricing-table th{background:var(--bg-secondary);font-weight:600;color:var(--text-muted)}.admin-pricing-table td:first-child{text-align:left;font-weight:500}.admin-pricing-table input[type=number]{padding:4px 8px;border:1px solid var(--line);border-radius:6px;background:var(--bg);color:var(--text);font-size:13px}.status-badge{display:inline-block;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600}.status-succeeded{background:var(--success-soft);color:var(--success)}.status-failed{background:var(--danger-soft);color:var(--danger)}.status-pending{background:var(--warning-soft);color:var(--warning)}.templates-page{max-width:1400px;margin:0 auto;padding:60px 24px;min-height:calc(100vh - 200px)}.templates-header{text-align:center;margin-bottom:48px}.templates-header h1{font-family:"Noto Serif SC",serif;font-size:48px;font-weight:700;background:linear-gradient(135deg,var(--text) 0%,var(--primary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:16px}.templates-header p{font-size:18px;color:var(--text-muted)}.templates-layout{display:grid;grid-template-columns:280px 1fr;gap:32px}.templates-sidebar{position:sticky;top:100px;height:-moz-fit-content;height:fit-content}.category-list{display:flex;flex-direction:column;gap:4px;background:var(--bg-card);border-radius:16px;padding:12px;border:1px solid var(--line)}.category-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border:none;background:transparent;color:var(--text-muted);font-size:15px;font-weight:500;cursor:pointer;border-radius:12px;transition:all .2s ease;text-align:left}.category-item:hover{background:var(--bg-soft);color:var(--text)}.category-item.active{background:var(--primary-soft);color:var(--primary)}.category-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center}.category-icon svg{width:20px;height:20px}.category-label{flex:1}.category-count{font-size:12px;background:var(--bg-soft);padding:2px 8px;border-radius:10px;color:var(--text-subtle)}.category-item.active .category-count{background:var(--primary);color:#fff}.templates-main{min-height:600px}.templates-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.templates-section-header h2{font-family:"Noto Serif SC",serif;font-size:28px;font-weight:600}.template-count{font-size:14px;color:var(--text-muted)}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.template-card{background:var(--bg-card);border:1px solid var(--line);border-radius:16px;overflow:hidden;cursor:pointer;transition:all .3s ease}.template-card:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:0 12px 40px #0003}.template-card-image{position:relative;height:180px;overflow:hidden}.template-card-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.template-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);opacity:.5}.template-card-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;opacity:.5;transition:opacity .3s ease}.template-card:hover .template-card-overlay{opacity:.8}.template-card-icon{width:48px;height:48px;color:#fff}.template-card-icon svg{width:100%;height:100%}.template-card-content{padding:16px}.template-card-content h3{font-size:16px;font-weight:600;margin-bottom:8px;color:var(--text)}.template-goal{font-size:13px;color:var(--text-muted);line-height:1.5;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.template-usecases{display:flex;flex-wrap:wrap;gap:6px}.usecase-tag{font-size:11px;padding:3px 8px;background:var(--bg-soft);color:var(--text-muted);border-radius:4px}.template-detail{max-width:1200px;margin:0 auto}.template-detail-back{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:var(--bg-soft);border:none;border-radius:10px;color:var(--text-muted);font-size:14px;cursor:pointer;margin-bottom:24px;transition:all .2s ease}.template-detail-back:hover{background:var(--bg-card);color:var(--text)}.template-detail-back svg{width:18px;height:18px}.template-detail-content{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}.template-detail-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#fff;text-align:center;padding:40px;background:linear-gradient(135deg,#667eea,#764ba2)}.template-detail-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#fff;text-align:center;padding:40px}.template-detail-icon{width:80px;height:80px;opacity:.7}.template-detail-icon svg{width:100%;height:100%}.template-detail-hint{font-size:14px;opacity:.8}.image-preview-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:9999;padding:40px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.image-preview-content{position:relative;max-width:90vw;max-height:90vh;display:flex;align-items:center;justify-content:center}.image-preview-content img{max-width:100%;max-height:90vh;-o-object-fit:contain;object-fit:contain;border-radius:8px;box-shadow:0 20px 60px #00000080;animation:scaleIn .2s ease}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.image-preview-close{position:absolute;top:-50px;right:0;background:#ffffff1a;border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease}.image-preview-close:hover{background:#fff3}.image-preview-close svg{width:24px;height:24px;color:#fff}.template-detail-image{position:sticky;top:100px;border-radius:20px;overflow:hidden;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center}.template-detail-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .3s ease}.template-detail-image:hover img{transform:scale(1.02)}.template-detail-zoom-hint{position:absolute;bottom:16px;right:16px;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:8px 12px;border-radius:20px;display:flex;align-items:center;gap:6px;font-size:12px;color:#fff;opacity:0;transition:opacity .3s ease}.template-detail-image:hover .template-detail-zoom-hint{opacity:1}.template-detail-zoom-hint svg{width:16px;height:16px}.template-detail-info h1{font-family:"Noto Serif SC",serif;font-size:28px;font-weight:700;margin-bottom:12px}.template-detail-goal{font-size:16px;color:var(--text-muted);line-height:1.6;margin-bottom:24px}.template-section{margin-bottom:20px}.template-section h4{font-size:12px;font-weight:600;color:var(--text-subtle);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.usecase-list{display:flex;flex-wrap:wrap;gap:8px}.usecase-tag{font-size:13px;padding:6px 12px;background:var(--bg-soft);color:var(--text-muted);border-radius:6px}.prompt-box{background:var(--bg-soft);border:1px solid var(--line);border-radius:12px;padding:16px}.prompt-box p{font-size:14px;line-height:1.7;color:var(--text)}.template-use-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px;font-size:16px;font-weight:600;margin-top:32px;border-radius:12px}.template-use-btn svg{width:20px;height:20px}@media (max-width: 1024px){.templates-layout{grid-template-columns:1fr}.templates-sidebar{position:static}.category-list{flex-direction:row;flex-wrap:wrap;gap:8px;overflow-x:auto}.category-item{flex-shrink:0}.template-detail-content{grid-template-columns:1fr}.template-detail-image{position:static}}@media (max-width: 768px){.templates-page{padding:40px 16px}.templates-header h1{font-size:36px}.template-grid{grid-template-columns:1fr}}@media (max-width: 768px){.nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--bg-elevated);border-bottom:1px solid var(--line);flex-direction:column;padding:12px 16px;gap:4px;box-shadow:0 8px 24px #00000026;z-index:99}.nav.nav-open{display:flex}.nav-link{padding:12px 16px;border-radius:10px;font-size:15px}.nav-link.active{background:var(--primary-soft)}.mobile-menu-btn{display:flex}.hero-title{font-size:36px}.hero{padding:40px 0 60px}.composer-controls{flex-direction:column;align-items:stretch}.composer-footer{flex-direction:column}.pricing-grid{grid-template-columns:1fr}.credits-chip span,.user-email{display:none}.top-logo{width:40px;height:40px}.profile-menu .profile-dropdown{display:none}.profile-menu.open .profile-dropdown{display:flex}.admin-layout{flex-direction:column}.admin-sidebar{width:100%;height:auto;position:static;border-right:none;border-bottom:1px solid var(--line);padding:16px}.admin-nav{flex-direction:row;overflow-x:auto;gap:8px}.admin-nav-item{flex-shrink:0;padding:8px 14px}.admin-main{padding:20px 16px 60px}.admin-stats{grid-template-columns:repeat(2,1fr)}.admin-form-grid{grid-template-columns:1fr}.admin-mini-stats{grid-template-columns:repeat(2,1fr)}.admin-detail-info{grid-template-columns:1fr}.admin-toolbar{flex-direction:column}.reverse-page{padding:30px 16px}.reverse-header h1{font-size:28px}.reverse-card{padding:20px}}.login-mode-tabs{display:flex;margin-bottom:24px;border-bottom:1px solid var(--line)}.login-mode-tab{flex:1;padding:14px 0;border:none;background:transparent;color:var(--text-muted);font-size:15px;font-weight:600;cursor:pointer;position:relative;transition:all .2s}.login-mode-tab.active{color:var(--primary)}.login-mode-tab.active:after{content:"";position:absolute;bottom:-1px;left:20%;right:20%;height:2px;background:var(--primary);border-radius:1px}.login-mode-tab:hover{color:var(--text)}.login-mode-hint{text-align:center;margin-top:16px;font-size:13px;color:var(--text-muted)}.login-mode-hint a{color:var(--primary);cursor:pointer;font-weight:600;margin-left:4px}.login-mode-hint a:hover{color:var(--primary-hover);text-decoration:underline}.verify-code-row{display:flex;gap:10px}.verify-code-input{flex:1}.verify-code-btn{flex-shrink:0;padding:10px 16px;font-size:13px;font-weight:500;border:1px solid var(--line);border-radius:12px;background:var(--bg-soft);color:var(--text-muted);cursor:pointer;transition:all .2s;white-space:nowrap}.verify-code-btn:hover:not(:disabled){color:var(--primary);border-color:var(--primary);background:var(--primary-soft)}.verify-code-btn:disabled{opacity:.6;cursor:not-allowed}.admin-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}.admin-search{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--bg-card);border:1px solid var(--line);border-radius:12px;min-width:260px}.admin-search svg{width:16px;height:16px;color:var(--text-muted);flex-shrink:0}.admin-search input{border:none;background:transparent;color:var(--text);font-size:14px;outline:none;width:100%}.admin-search input::-moz-placeholder{color:var(--text-subtle)}.admin-search input::placeholder{color:var(--text-subtle)}.admin-filters{display:flex;gap:6px}.admin-filters button{padding:8px 16px;border:1px solid var(--line);border-radius:10px;background:var(--bg-card);color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.admin-filters button:hover{color:var(--text);border-color:var(--line-strong)}.admin-filters button.active{color:var(--primary);border-color:var(--primary);background:var(--primary-soft)}.admin-detail-panel{background:var(--bg-card);border:1px solid var(--line);border-radius:20px;padding:28px;margin-bottom:24px}.admin-detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.admin-detail-back{display:flex;align-items:center;gap:6px;padding:8px 12px;border:1px solid var(--line);border-radius:8px;background:transparent;color:var(--text-muted);font-size:13px;cursor:pointer;transition:all .2s}.admin-detail-back:hover{color:var(--text);border-color:var(--line-strong)}.admin-detail-back svg{width:16px;height:16px}.admin-detail-info{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}.admin-detail-info-item{display:flex;flex-direction:column;gap:4px}.admin-detail-info-item label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600}.admin-detail-info-item span{font-size:15px;font-weight:500}.admin-mini-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:28px}.admin-mini-stat{padding:16px;border-radius:14px;background:var(--bg-soft);border:1px solid var(--line);text-align:center}.admin-mini-stat strong{display:block;font-size:24px;font-weight:800;color:var(--primary)}.admin-mini-stat span{font-size:12px;color:var(--text-muted);margin-top:2px;display:block}.admin-pagination{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:20px;font-size:14px;color:var(--text-muted)}.admin-pagination button{padding:8px 16px;border:1px solid var(--line);border-radius:10px;background:var(--bg-card);color:var(--text-muted);font-size:13px;cursor:pointer;transition:all .2s}.admin-pagination button:hover:not(:disabled){color:var(--text);border-color:var(--line-strong)}.admin-pagination button:disabled{opacity:.4;cursor:not-allowed}.table-actions{display:flex;gap:6px}.table-action-btn{padding:4px 10px;border:1px solid var(--line);border-radius:6px;background:var(--bg-soft);color:var(--text-muted);font-size:12px;cursor:pointer;transition:all .15s;white-space:nowrap}.table-action-btn:hover{color:var(--primary);border-color:var(--primary);background:var(--primary-soft)}.table-action-btn.danger:hover{color:var(--danger);border-color:var(--danger);background:var(--danger-soft)}.gen-thumb{transition:transform .15s,box-shadow .15s}.gen-thumb:hover{transform:scale(1.08);box-shadow:0 0 12px var(--primary-glow)}.featured-admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.featured-admin-card{background:var(--bg-card);border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:border-color .2s}.featured-admin-card:hover{border-color:var(--line-strong)}.featured-admin-image{width:100%;aspect-ratio:1;overflow:hidden;cursor:pointer;background:var(--bg-soft)}.featured-admin-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .2s}.featured-admin-image:hover img{transform:scale(1.04)}.featured-admin-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:14px}.featured-admin-info{padding:12px}.featured-admin-prompt{font-size:13px;color:var(--text);line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:10px}.featured-admin-actions{display:flex;gap:6px}.admin-chart-controls{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.admin-chart-controls h2{font-size:18px;font-weight:700}.admin-charts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:32px}.admin-chart-card{background:var(--bg-card);border:1px solid var(--line);border-radius:20px;padding:20px}.admin-chart-card h3{font-size:14px;font-weight:600;color:var(--text-muted);margin-bottom:16px}@media (max-width: 1200px){.admin-charts-grid{grid-template-columns:1fr 1fr}}@media (max-width: 768px){.admin-charts-grid{grid-template-columns:1fr}.admin-chart-controls{flex-direction:column;gap:12px;align-items:flex-start}}.announcement-bell{position:relative;width:40px;height:40px;border-radius:12px;border:1px solid var(--line);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.announcement-bell:hover{color:var(--primary);border-color:var(--primary);background:var(--primary-soft)}.announcement-bell svg{width:20px;height:20px}.announcement-bell-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--danger);border:2px solid var(--bg-elevated)}.announcement-modal{max-width:440px}.announcement-modal-text{font-size:15px;line-height:1.8;color:var(--text);white-space:pre-wrap}.reverse-page{max-width:680px;margin:0 auto;padding:60px 20px}.reverse-header{text-align:center;margin-bottom:40px}.reverse-header h1{font-family:"Noto Serif SC",serif;font-size:36px;font-weight:700;letter-spacing:-.02em;margin-bottom:12px}.reverse-header p{font-size:16px;color:var(--text-muted)}.reverse-card{background:var(--bg-card);border:1px solid var(--line);border-radius:24px;padding:32px}.reverse-upload-area{border:2px dashed var(--line);border-radius:16px;padding:48px 24px;text-align:center;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:12px}.reverse-upload-area:hover,.reverse-upload-area.drag-over{border-color:var(--accent);background:var(--bg-soft)}.reverse-upload-area svg{width:40px;height:40px;color:var(--text-muted)}.reverse-upload-area span{font-size:15px;color:var(--text-muted)}.reverse-upload-hint{font-size:13px!important;opacity:.6}.reverse-preview-wrap{position:relative;border-radius:16px;overflow:hidden}.reverse-preview{width:100%;max-height:400px;-o-object-fit:contain;object-fit:contain;border-radius:16px;background:var(--bg-soft)}.reverse-clear-btn{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;background:#0009;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.reverse-clear-btn svg{width:16px;height:16px}.reverse-action-bar{display:flex;align-items:center;gap:16px;margin-top:24px}.reverse-cost-hint{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--text-muted)}.reverse-error{margin-top:16px;padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:12px;color:var(--danger);font-size:14px}.reverse-result{margin-top:24px}.reverse-result label{display:block;font-size:13px;font-weight:600;color:var(--text-muted);margin-bottom:8px}.reverse-result textarea{width:100%;padding:16px;border:1px solid var(--line);border-radius:12px;background:var(--bg-soft);color:var(--text);font-size:14px;line-height:1.6;resize:vertical;font-family:inherit}.reverse-result-actions{display:flex;gap:12px;margin-top:16px}.admin-monitor-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}.admin-monitor-card{padding:20px;border-radius:16px;background:var(--bg-card);border:1px solid var(--line);text-align:center}.admin-monitor-card h3{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:10px}.admin-monitor-value{font-size:28px;font-weight:800}.admin-monitor-value.green{color:var(--success)}.admin-monitor-value.yellow{color:var(--warning)}.admin-monitor-value.red{color:var(--danger)}.admin-monitor-sub{font-size:12px;color:var(--text-muted);margin-top:4px}@media (max-width: 1024px){.admin-monitor-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.admin-monitor-grid{grid-template-columns:1fr 1fr}}.admin-template-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}.admin-template-toolbar .admin-search{flex:1;max-width:400px}.admin-batch-toolbar{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--primary-soft);border:1px solid var(--primary);border-radius:12px;margin-bottom:16px;font-size:14px;flex-wrap:wrap}.admin-batch-toolbar span{color:var(--primary);font-weight:600}.admin-table th input[type=checkbox],.admin-table td input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.admin-emails-add{display:flex;gap:10px;align-items:center}.admin-emails-add input{flex:1}.admin-emails-list{display:flex;flex-direction:column;gap:8px}.admin-emails-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-soft);border:1px solid var(--line);border-radius:12px}.admin-emails-item svg{width:20px;height:20px;color:var(--primary);flex-shrink:0}.admin-emails-item span{flex:1;font-size:14px;font-weight:500}.apikeys-error{display:flex;align-items:center;gap:10px;padding:14px 18px;background:var(--danger-soft);border:1px solid rgba(239,68,68,.2);border-radius:12px;color:var(--danger);font-size:14px;margin-bottom:20px}.apikeys-error svg{flex-shrink:0}.apikeys-warning{display:flex;align-items:center;gap:10px;padding:14px 18px;background:var(--warning-soft);border:1px solid rgba(245,158,11,.2);border-radius:12px;color:var(--warning);font-size:14px;margin-bottom:20px}.apikeys-warning svg{flex-shrink:0}.apikeys-create-form{display:flex;align-items:center;gap:12px;padding:20px;background:var(--bg-card);border:1px solid var(--line);border-radius:16px;margin-bottom:24px}.apikeys-name-input{flex:1;padding:12px 16px;border:1px solid var(--line);border-radius:12px;background:var(--bg-soft);color:var(--text);font-size:14px;outline:none;transition:border-color .2s}.apikeys-name-input:focus{border-color:var(--primary)}.apikeys-name-input::-moz-placeholder{color:var(--text-subtle)}.apikeys-name-input::placeholder{color:var(--text-subtle)}.apikeys-loading{text-align:center;padding:60px 20px;color:var(--text-muted);font-size:15px}.apikeys-empty{text-align:center;padding:80px 20px;color:var(--text-muted)}.apikeys-empty svg{color:var(--text-subtle);margin-bottom:16px}.apikeys-empty h3{font-size:18px;font-weight:600;color:var(--text);margin-bottom:8px}.apikeys-empty p{font-size:14px;color:var(--text-muted)}.apikeys-table-wrapper{background:var(--bg-card);border:1px solid var(--line);border-radius:16px;overflow:hidden}.apikeys-table{width:100%;border-collapse:collapse}.apikeys-table th{padding:14px 20px;text-align:left;font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;background:var(--bg-soft);border-bottom:1px solid var(--line)}.apikeys-table td{padding:16px 20px;font-size:14px;color:var(--text);border-bottom:1px solid var(--line)}.apikeys-table tr:last-child td{border-bottom:none}.apikeys-table tr:hover td{background:var(--bg-soft)}.apikeys-name{font-weight:500}.apikeys-key code{font-family:SF Mono,Fira Code,monospace;font-size:13px;padding:4px 10px;background:var(--bg-soft);border:1px solid var(--line);border-radius:6px;color:var(--text-muted)}.apikeys-date{color:var(--text-muted);font-size:13px}.btn-danger-outline{padding:6px 14px;border:1px solid rgba(239,68,68,.3);border-radius:8px;background:transparent;color:var(--danger);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.btn-danger-outline:hover{background:var(--danger-soft);border-color:var(--danger)}.apikeys-created-warning{display:flex;align-items:flex-start;gap:10px;padding:14px 16px;background:var(--warning-soft);border:1px solid rgba(245,158,11,.2);border-radius:10px;color:var(--warning);font-size:14px;margin-bottom:20px}.apikeys-created-warning svg{flex-shrink:0;margin-top:2px}.apikeys-key-display{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-soft);border:1px solid var(--line);border-radius:10px}.apikeys-key-display code{flex:1;font-family:SF Mono,Fira Code,monospace;font-size:14px;color:var(--text);word-break:break-all}.apikeys-key-display .btn{flex-shrink:0}@media (max-width: 768px){.apikeys-create-form{flex-direction:column;align-items:stretch}.apikeys-table-wrapper{overflow-x:auto}.apikeys-table th,.apikeys-table td{padding:12px 14px;white-space:nowrap}}.api-page-layout{display:flex;min-height:calc(100vh - 80px);position:relative;z-index:1}.api-sidebar{width:240px;flex-shrink:0;border-right:1px solid var(--line);background:var(--bg-card);padding:24px 0;position:sticky;top:0;height:calc(100vh - 80px);overflow-y:auto;align-self:flex-start}.api-sidebar-header{display:flex;align-items:center;gap:10px;padding:0 20px 20px;font-size:16px;font-weight:700;color:var(--text);border-bottom:1px solid var(--line);margin-bottom:16px}.api-sidebar-header svg{color:var(--primary)}.api-sidebar-nav{padding:0 12px}.api-sidebar-group{margin-bottom:4px}.api-sidebar-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;background:transparent;color:var(--text-muted);font-size:14px;font-weight:500;cursor:pointer;border-radius:8px;text-align:left;transition:all .15s}.api-sidebar-item:hover{background:var(--bg-soft);color:var(--text)}.api-sidebar-item.active{background:var(--primary-soft);color:var(--primary)}.api-sidebar-item svg:first-child{flex-shrink:0}.api-sidebar-chevron{margin-left:auto;transition:transform .2s}.api-sidebar-chevron.open{transform:rotate(180deg)}.api-sidebar-children{padding-left:38px;margin-top:2px}.api-sidebar-child{display:block;width:100%;padding:7px 12px;border:none;background:transparent;color:var(--text-muted);font-size:13px;cursor:pointer;border-radius:6px;text-align:left;transition:all .15s}.api-sidebar-child:hover{background:var(--bg-soft);color:var(--text)}.api-sidebar-child.active{background:var(--primary-soft);color:var(--primary);font-weight:600}.api-page-content{flex:1;min-width:0;overflow-y:auto}.api-page-content .history-page,.api-page-content .apidocs-page{padding:32px 24px 60px}@media (max-width: 768px){.api-page-layout{flex-direction:column}.api-sidebar{width:100%;height:auto;position:static;border-right:none;border-bottom:1px solid var(--line);padding:16px 0}.api-sidebar-nav{display:flex;gap:4px;padding:0 16px;overflow-x:auto}.api-sidebar-group{margin-bottom:0}.api-sidebar-children{display:none}}.apidocs-page{max-width:1600px;margin:0 auto;padding:48px 24px 100px;position:relative;z-index:1}.apidocs-container{max-width:900px;margin:0 auto}.apidocs-hero{text-align:center;padding:40px 0 48px;border-bottom:1px solid var(--line);margin-bottom:40px}.apidocs-hero-title{font-family:Noto Sans SC,-apple-system,sans-serif;font-size:36px;font-weight:700;margin-bottom:12px;letter-spacing:-.02em}.apidocs-hero-subtitle{font-size:16px;color:var(--text-muted);margin-bottom:24px;line-height:1.6}.apidocs-hero-actions{display:flex;justify-content:center;gap:12px}.apidocs-toc{background:var(--bg-card);border:1px solid var(--line);border-radius:16px;padding:24px;margin-bottom:48px}.apidocs-toc-title{font-size:14px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px}.apidocs-toc-list{list-style:none;display:flex;flex-wrap:wrap;gap:8px 24px}.apidocs-toc-list a{color:var(--primary);text-decoration:none;font-size:14px;font-weight:500;transition:color .2s}.apidocs-toc-list a:hover{color:var(--primary-hover);text-decoration:underline}.apidocs-section{margin-bottom:56px;scroll-margin-top:100px}.apidocs-section-title{font-size:24px;font-weight:700;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--line)}.apidocs-subtitle{font-size:16px;font-weight:600;margin-top:28px;margin-bottom:12px;color:var(--text)}.apidocs-text{font-size:15px;color:var(--text-muted);line-height:1.7;margin-bottom:16px}.apidocs-text code{font-family:SF Mono,Fira Code,monospace;font-size:13px;background:var(--bg-soft);border:1px solid var(--line);border-radius:6px;padding:2px 6px;color:var(--primary)}.apidocs-text a{color:var(--primary);text-decoration:none}.apidocs-text a:hover{text-decoration:underline}.apidocs-endpoint{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-card);border:1px solid var(--line);border-radius:12px;margin-bottom:16px}.apidocs-method{font-family:SF Mono,Fira Code,monospace;font-size:12px;font-weight:700;padding:4px 10px;border-radius:6px;text-transform:uppercase;letter-spacing:.05em}.apidocs-method.post{background:var(--primary-soft);color:var(--primary)}.apidocs-url{font-family:SF Mono,Fira Code,monospace;font-size:14px;color:var(--text)}.apidocs-table-wrapper{background:var(--bg-card);border:1px solid var(--line);border-radius:12px;overflow:hidden;margin-bottom:16px}.apidocs-table{width:100%;border-collapse:collapse}.apidocs-table th{padding:12px 16px;text-align:left;font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;background:var(--bg-soft);border-bottom:1px solid var(--line)}.apidocs-table td{padding:12px 16px;font-size:14px;border-bottom:1px solid var(--line);vertical-align:top}.apidocs-table tr:last-child td{border-bottom:none}.apidocs-table tr:hover td{background:#ffffff05}.apidocs-table code{font-family:SF Mono,Fira Code,monospace;font-size:13px;background:var(--bg-soft);border:1px solid var(--line);border-radius:4px;padding:2px 6px;color:var(--primary)}.apidocs-badge{display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;border-radius:4px}.apidocs-badge.required{background:var(--danger-soft);color:var(--danger)}.apidocs-badge.optional{background:var(--bg-soft);color:var(--text-muted);border:1px solid var(--line)}.apidocs-codeblock{border-radius:12px;overflow:hidden;border:1px solid var(--line);margin-bottom:16px}.apidocs-codeblock-header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:var(--bg-soft);border-bottom:1px solid var(--line)}.apidocs-codeblock-lang{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.apidocs-codeblock-copy{display:flex;align-items:center;gap:4px;padding:4px 10px;border:1px solid var(--line);border-radius:6px;background:var(--bg);color:var(--text-muted);font-size:12px;cursor:pointer;transition:all .2s}.apidocs-codeblock-copy:hover{color:var(--text);border-color:var(--line-strong);background:var(--bg-elevated)}.apidocs-codeblock-pre{padding:16px;margin:0;overflow-x:auto;background:#0d0d0f;font-family:SF Mono,Fira Code,monospace;font-size:13px;line-height:1.6;color:#e4e4e7}[data-theme=light] .apidocs-codeblock-pre{background:#1e1e2e;color:#e4e4e7}.apidocs-codetabs{margin-bottom:16px}.apidocs-codetabs-header{display:flex;gap:0;border-bottom:1px solid var(--line);margin-bottom:0}.apidocs-codetabs-tab{padding:10px 20px;border:none;background:transparent;color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .2s}.apidocs-codetabs-tab:hover{color:var(--text)}.apidocs-codetabs-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.apidocs-codetabs .apidocs-codeblock{border-top-left-radius:0;border-top-right-radius:0;border-top:none;margin-bottom:0}.apidocs-note{display:flex;align-items:flex-start;gap:10px;padding:14px 18px;background:var(--warning-soft);border:1px solid rgba(245,158,11,.2);border-radius:12px;color:var(--warning);font-size:14px;margin-top:16px}.apidocs-note svg{flex-shrink:0;margin-top:2px}.apidocs-rate-limit-info{display:flex;gap:16px;margin-bottom:20px}.apidocs-rate-limit-card{display:flex;flex-direction:column;align-items:center;padding:24px 40px;background:var(--bg-card);border:1px solid var(--line);border-radius:16px}.apidocs-rate-limit-value{font-family:Fredoka,sans-serif;font-size:48px;font-weight:700;color:var(--primary);line-height:1;margin-bottom:8px}.apidocs-rate-limit-label{font-size:14px;color:var(--text-muted);font-weight:500}@media (max-width: 768px){.apidocs-page{padding:24px 16px 60px}.apidocs-hero-title{font-size:28px}.apidocs-toc-list{flex-direction:column;gap:8px}.apidocs-endpoint{flex-direction:column;align-items:flex-start;gap:8px}.apidocs-url{font-size:12px;word-break:break-all}.apidocs-table-wrapper{overflow-x:auto}.apidocs-table th,.apidocs-table td{padding:10px 12px;white-space:nowrap}.apidocs-codetabs-tab{padding:8px 14px;font-size:12px}}
