*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}.App{min-height:100vh;padding:2rem}.container{max-width:1400px;margin:0 auto}.header{text-align:center;color:#fff;margin-bottom:3rem}.header h1{font-size:3rem;margin-bottom:.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.header p{font-size:1.2rem;opacity:.95}.tabs{display:flex;gap:1rem;margin-bottom:2rem;justify-content:center}.tab{padding:1rem 2.5rem;background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.3);border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tab:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-2px)}.tab.active{background:#fff;color:#667eea;border-color:#fff;box-shadow:0 4px 15px #0003}.content{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}.card{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 10px 30px #0003;margin-bottom:1.5rem}.card h2{font-size:1.5rem;margin-bottom:1rem;color:#333}.image-upload-container{width:100%;min-height:250px}.upload-label{display:block;cursor:pointer;width:100%;height:250px}.upload-placeholder{border:3px dashed #ddd;border-radius:12px;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:all .3s ease;background:#fafafa}.upload-placeholder:hover{border-color:#667eea;background:#f0f4ff}.upload-icon{font-size:3rem;margin-bottom:1rem}.upload-placeholder p{font-size:1.1rem;color:#333;margin-bottom:.5rem}.upload-hint{font-size:.9rem;color:#666}.image-preview{position:relative;width:100%;height:250px;border-radius:12px;overflow:hidden}.image-preview img{width:100%;height:100%;object-fit:cover;border-radius:12px}.clear-button{position:absolute;top:10px;right:10px;background:#000000b3;color:#fff;border:none;border-radius:50%;width:36px;height:36px;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.clear-button:hover{background:#f00c;transform:scale(1.1)}.prompt-section{display:flex;flex-direction:column;gap:1rem}.template-selector{display:flex;flex-direction:column;gap:.5rem}.template-label{font-size:.95rem;font-weight:500;color:#555}.template-select{width:100%;padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:10px;font-size:.95rem;font-family:inherit;background:linear-gradient(to right,#f8f9ff,#fff);cursor:pointer;transition:all .3s ease;color:#333;font-weight:500}.template-select:hover{border-color:#667eea;background:linear-gradient(to right,#f0f4ff,#fff)}.template-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.prompt-input{width:100%;padding:1rem;border:2px solid #e0e0e0;border-radius:12px;font-size:1rem;font-family:inherit;resize:vertical;transition:border-color .3s ease}.prompt-input:focus{outline:none;border-color:#667eea}.aspect-ratio-select{width:100%;padding:1rem;border:2px solid #e0e0e0;border-radius:12px;font-size:1rem;font-family:inherit;background:#fff;cursor:pointer;transition:border-color .3s ease}.aspect-ratio-select:focus{outline:none;border-color:#667eea}.aspect-ratio-select:hover{border-color:#667eea}.generate-button{width:100%;padding:1.2rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.generate-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.generate-button:disabled{opacity:.6;cursor:not-allowed}.spinner{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.spinner-large{width:60px;height:60px;border:4px solid #f3f3f3;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.output-container{min-height:400px;display:flex;align-items:center;justify-content:center}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#666}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#999}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.generated-image-container{width:100%;display:flex;flex-direction:column;gap:1rem}.generated-image{width:100%;height:auto;border-radius:12px;box-shadow:0 4px 12px #0000001a}.generated-video-container{width:100%;display:flex;flex-direction:column;gap:1rem}.generated-video{width:100%;height:auto;border-radius:12px;box-shadow:0 4px 12px #0000001a;background:#000}.gcs-video-info{text-align:center;padding:2rem}.gcs-video-info h3{color:#10b981;margin-bottom:1rem;font-size:1.5rem}.gcs-video-info p{color:#666;margin-bottom:1rem;line-height:1.6}.gcs-uri{display:block;background:#f5f5f5;padding:1rem;border-radius:8px;color:#333;font-family:Courier New,monospace;font-size:.9rem;word-break:break-all;margin:1rem 0;border:1px solid #e0e0e0}.gcs-note{font-size:.9rem;color:#999;font-style:italic}.download-button{padding:.8rem 1.5rem;background:#10b981;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.download-button:hover{background:#059669;transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.error-message{background:#fee;border:1px solid #fcc;color:#c33;padding:1rem;border-radius:8px;margin-top:1rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:20px;padding:2.5rem;box-shadow:0 20px 60px #0000004d;max-width:450px;width:90%;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-content h2{font-size:2rem;margin-bottom:.5rem;color:#333;text-align:center}.modal-content p{color:#666;margin-bottom:1.5rem;font-size:1rem;text-align:center}.modal-content form{display:flex;flex-direction:column;gap:1rem}.password-input{width:100%;padding:1rem;border:2px solid #e0e0e0;border-radius:12px;font-size:1rem;font-family:inherit;transition:border-color .3s ease}.password-input:focus{outline:none;border-color:#667eea}.password-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.modal-buttons{display:flex;gap:1rem;margin-top:.5rem}.cancel-button{flex:1;padding:1rem 1.5rem;background:#e0e0e0;color:#333;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.cancel-button:hover:not(:disabled){background:#d0d0d0;transform:translateY(-2px)}.cancel-button:disabled{opacity:.6;cursor:not-allowed}.submit-button{flex:1;padding:1rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.submit-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 968px){.content{grid-template-columns:1fr}.header h1{font-size:2rem}.App{padding:1rem}.tabs{flex-direction:column;gap:.75rem}.tab{padding:.875rem 1.5rem;font-size:1rem}.modal-content{padding:2rem;width:95%}.modal-content h2{font-size:1.5rem}.modal-buttons{flex-direction:column}}body{margin:0;padding:0}
