*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #1a1a2e;--bg-raised: #16213e;--bg-card: #0f3460;--blue: #4a90d9;--green: #50c878;--orange: #f5a623;--red: #e74c3c;--text: #ecf0f1;--muted: #7f8c8d;--border: rgba(74, 144, 217, .25);--radius: 10px;--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:Inter,Segoe UI,system-ui,sans-serif;font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased}.generator{max-width:900px;margin:0 auto;padding:2rem 1.5rem 6rem;display:flex;flex-direction:column;gap:2.5rem}.model-config{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.2rem;display:flex;flex-direction:column;gap:.75rem}.config-label{font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;min-width:80px}.model-select-row{display:flex;align-items:center;gap:.75rem}.model-select{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.9rem;padding:.5rem .8rem;outline:none;cursor:pointer;transition:border-color .2s}.model-select:focus{border-color:var(--blue)}.api-key-row{display:flex;align-items:center;gap:.75rem}.api-key-input{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font-mono);font-size:.78rem;padding:.5rem .8rem;outline:none;transition:border-color .2s}.api-key-input:focus{border-color:var(--blue)}.api-key-input::placeholder{color:var(--muted)}.toggle-key-btn{background:transparent;border:1px solid var(--border);border-radius:var(--radius);color:var(--muted);font-size:.8rem;padding:.5rem .8rem;cursor:pointer;white-space:nowrap;transition:color .2s,border-color .2s}.toggle-key-btn:hover{color:var(--text);border-color:var(--blue)}.save-key-btn{background:transparent;border:1px solid var(--border);border-radius:var(--radius);color:var(--muted);font-size:.8rem;padding:.5rem .9rem;cursor:pointer;white-space:nowrap;transition:color .2s,border-color .2s,background .2s}.save-key-btn:hover{color:var(--text);border-color:var(--blue)}.save-key-btn.saved{color:var(--green);border-color:var(--green);background:#50c87814}.email-row{display:flex;align-items:center;gap:.75rem}.fetch-error{margin:1rem auto;max-width:720px;padding:.75rem 1rem;background:#ff50501a;border:1px solid rgba(255,80,80,.4);border-radius:var(--radius);color:#ff6b6b;font-size:.9rem}.hero{text-align:center;padding-top:1rem}.hero-title{font-size:clamp(2.2rem,5vw,3.5rem);font-weight:800;letter-spacing:-.03em;color:var(--text)}.hero-title .accent{color:var(--blue)}.hero-sub{margin-top:.75rem;font-size:1.05rem;color:var(--muted)}.prompt-input{display:flex;flex-direction:column;gap:.85rem}.topic-textarea{width:100%;background:var(--bg-raised);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:1rem;padding:1rem 1.2rem;resize:vertical;outline:none;transition:border-color .2s;font-family:inherit}.topic-textarea:focus{border-color:var(--blue)}.topic-textarea::placeholder{color:var(--muted)}.topic-textarea:disabled{opacity:.5;cursor:not-allowed}.generate-btn{align-self:flex-start;background:var(--blue);color:#fff;border:none;border-radius:var(--radius);padding:.75rem 2rem;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .2s,transform .15s}.generate-btn:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.generate-btn:disabled{opacity:.45;cursor:not-allowed}.examples{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.examples-label{font-size:.85rem;color:var(--muted);margin-right:.25rem}.chip{background:var(--bg-raised);border:1px solid var(--border);border-radius:999px;color:var(--text);font-size:.8rem;padding:.3rem .9rem;cursor:pointer;transition:background .2s,border-color .2s}.chip:hover:not(:disabled){background:var(--bg-card);border-color:var(--blue)}.chip:disabled{opacity:.4;cursor:not-allowed}.progress-tracker{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.steps-row{display:flex;align-items:flex-start;gap:0}.step{display:flex;flex-direction:column;align-items:center;position:relative;flex:1}.step-dot{width:2rem;height:2rem;border-radius:50%;background:var(--bg);border:2px solid var(--muted);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:var(--muted);z-index:1;transition:all .3s}.step.done .step-dot{background:var(--green);border-color:var(--green);color:#0d2e1a}.step.active .step-dot{background:var(--bg-card);border-color:var(--blue);color:var(--blue)}.step-label{margin-top:.5rem;font-size:.75rem;color:var(--muted);text-align:center;white-space:nowrap}.step.done .step-label,.step.active .step-label{color:var(--text)}.step-line{position:absolute;top:1rem;left:50%;width:100%;height:2px;background:var(--muted);z-index:0;transition:background .3s}.step-line.done{background:var(--green)}.spinner{display:inline-block;width:.8rem;height:.8rem;border:2px solid transparent;border-top-color:var(--blue);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.repair-notice{font-size:.875rem;color:var(--orange);text-align:center}.error-box{background:#e74c3c1a;border:1px solid var(--red);border-radius:6px;padding:1rem;color:var(--red)}.error-box pre{margin-top:.5rem;font-size:.75rem;white-space:pre-wrap;word-break:break-word;color:var(--text);font-family:var(--font-mono)}.results{display:flex;flex-direction:column;gap:2rem}.video-player{display:flex;flex-direction:column;gap:.75rem;align-items:flex-start}.video-element{width:100%;border-radius:var(--radius);border:1px solid var(--border);background:#000;max-height:540px}.download-btn{display:inline-block;background:var(--bg-raised);border:1px solid var(--border);border-radius:6px;color:var(--text);padding:.5rem 1.25rem;text-decoration:none;font-size:.875rem;transition:background .2s}.download-btn:hover{background:var(--bg-card);border-color:var(--blue)}.code-viewer{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.code-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--border)}.code-title{font-size:.875rem;font-weight:600;color:var(--blue)}.copy-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text);padding:.3rem .85rem;font-size:.8rem;cursor:pointer;transition:background .2s}.copy-btn:hover{background:var(--blue);border-color:var(--blue)}.code-block{margin:0;padding:1.25rem;overflow-x:auto;font-family:var(--font-mono);font-size:.8rem;line-height:1.65;color:var(--text);max-height:500px;overflow-y:auto}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
