@import "https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700&display=swap";:root{--bg-base:#f8fafc;--bg-surface:#fff;--bg-surface-elevated:#f1f5f9;--border-color:#e2e8f0;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--accent:#bef264;--accent-hover:#a3e635;--accent-text:#022c22;--error-bg:#fef2f2;--error-border:#f87171;--error-text:#991b1b;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--spotlight-color:#00000005}.dark-theme{--bg-base:#09090b;--bg-surface:#121214;--bg-surface-elevated:#1e1e24;--border-color:#27272a;--text-primary:#fff;--text-secondary:#a1a1aa;--text-muted:#71717a;--accent:#d9f95d;--accent-hover:#e5ff7a;--accent-text:#09090b;--error-bg:#451a1a;--error-border:#7f1d1d;--error-text:#fca5a5;--shadow-sm:0 1px 2px 0 #00000080;--shadow-md:0 4px 6px -1px #00000080, 0 2px 4px -1px #0006;--shadow-lg:0 20px 40px -10px #0009, 0 10px 20px -5px #00000080;--glow-accent:0 0 20px #d9f95d26}body{background-color:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;margin:0;font-family:Outfit,system-ui,-apple-system,sans-serif;transition:background-color .2s,color .2s}.layout-wrapper{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1;padding-bottom:4rem}.container{max-width:1100px;margin:0 auto;padding:0 1.5rem}.app-header{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:1.5rem;display:flex}.theme-toggle{background:var(--bg-surface);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex}.theme-toggle:hover{background:var(--bg-surface-elevated);color:var(--text-primary)}h1,h2,h3,h4,p{margin:0}input,select,textarea,button{box-sizing:border-box;font-family:inherit}.beta-gate-overlay{z-index:1000;background:var(--bg-base);justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.mouse-spotlight{pointer-events:none;z-index:1;background:radial-gradient(600px circle at var(--mouse-x) var(--mouse-y), var(--spotlight-color), transparent 40%);opacity:0;width:100%;height:100%;transition:opacity .5s;position:absolute;top:0;left:0}.beta-gate-overlay:hover .mouse-spotlight{opacity:1}.beta-gate-card{background:var(--bg-surface);border:1px solid var(--border-color);text-align:center;width:100%;max-width:420px;box-shadow:var(--shadow-lg);border-radius:16px;padding:3rem 2.5rem;animation:.8s cubic-bezier(.16,1,.3,1) forwards betaGateEnter}@keyframes betaGateEnter{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.beta-shake{animation:.45s forwards betaShake}@keyframes betaShake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-5px)}80%{transform:translate(5px)}}.beta-gate-logo{justify-content:center;margin-bottom:2rem;display:flex}.beta-gate-header{margin-bottom:2rem}.beta-gate-title{color:var(--text-primary);letter-spacing:-.01em;margin-bottom:.5rem;font-size:1.35rem;font-weight:700}.beta-gate-subtitle{color:var(--text-secondary);font-size:.875rem;line-height:1.5}.beta-gate-input-group{text-align:left;margin-bottom:1.5rem}.beta-gate-input{background:var(--bg-base);border:1px solid var(--border-color);width:100%;color:var(--text-primary);text-align:center;letter-spacing:.08em;border-radius:10px;outline:none;padding:.9rem 1rem;font-size:.95rem;transition:all .3s cubic-bezier(.16,1,.3,1)}.beta-gate-input::placeholder{color:var(--text-muted);letter-spacing:normal}.beta-gate-input:focus{border-color:var(--accent);background:var(--bg-surface)}.beta-gate-input-error{border-color:var(--error-border)!important}.beta-gate-error{color:var(--error-text);text-align:center;margin-top:.5rem;font-size:.75rem}.beta-gate-btn-primary{background:var(--accent);width:100%;color:var(--accent-text);cursor:pointer;border:none;border-radius:8px;margin-bottom:.75rem;padding:.85rem 1rem;font-size:.95rem;font-weight:600;transition:all .2s}.beta-gate-btn-primary:hover{background:var(--accent-hover)}.beta-gate-btn-secondary{width:100%;color:var(--text-secondary);border:1px solid var(--border-color);cursor:pointer;box-sizing:border-box;background:0 0;border-radius:8px;padding:.75rem 1rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .2s;display:block}.beta-gate-btn-secondary:hover{color:var(--text-primary);border-color:var(--text-secondary)}.hero-header{text-align:center;margin-top:2rem;margin-bottom:3rem}.hero-title{letter-spacing:-.02em;margin-bottom:.75rem;font-size:2.5rem;font-weight:700}.hero-subtitle{color:var(--text-secondary);font-size:1.1rem}.command-center{background:var(--bg-surface);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);border-radius:20px;max-width:1080px;margin:0 auto;padding:2.5rem;position:relative;overflow:hidden}.input-section{flex-direction:column;gap:1.5rem;display:flex}.url-bar{gap:.75rem;display:flex}.url-input{background:var(--bg-base);border:1px solid var(--border-color);color:var(--text-primary);border-radius:8px;outline:none;flex-grow:1;padding:1rem 1.25rem;font-size:1rem;transition:border-color .2s}.url-input:focus{border-color:var(--text-secondary)}.primary-btn{background:var(--accent);color:var(--accent-text);cursor:pointer;white-space:nowrap;border:none;border-radius:10px;padding:0 2rem;font-size:1rem;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1)}.primary-btn:hover{background:var(--accent-hover)}.primary-btn:disabled{opacity:.5;cursor:not-allowed}.divider-minimal{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;align-items:center;margin:2rem 0;font-size:.75rem;display:flex}.divider-minimal:before,.divider-minimal:after{content:"";border-bottom:1px solid var(--border-color);flex:1}.divider-minimal span{padding:0 1rem}.manual-inputs{align-items:stretch;gap:2rem;display:flex}.manual-col{flex-direction:column;display:flex}.manual-inputs .manual-col:first-child{flex:0 0 320px}.manual-inputs .manual-col:last-child{flex:1}.input-label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.dropzone-minimal{border:1.5px dashed var(--border-color);background:var(--bg-base);border-radius:12px;flex-direction:column;justify-content:center;align-items:center;height:160px;transition:border-color .2s,box-shadow .2s,background .2s;display:flex;position:relative;overflow:hidden}.dropzone-stretch{flex:1;height:auto;min-height:220px}.dropzone-minimal:hover{border-color:var(--text-secondary);background:var(--bg-surface-elevated)}.dropzone-minimal.has-images{border-color:var(--accent);background:var(--bg-surface);border-style:solid}.dropzone-minimal input{opacity:0;cursor:pointer;z-index:2;width:100%;height:100%;position:absolute;inset:0}.dropzone-empty{text-align:center;pointer-events:none;flex-direction:column;justify-content:center;align-items:center;gap:.35rem;padding:1.5rem;display:flex}.dropzone-svg-wrap{background:var(--bg-surface);border:1px solid var(--border-color);width:52px;height:52px;color:var(--text-muted);border-radius:12px;justify-content:center;align-items:center;margin-bottom:.75rem;transition:all .2s;display:flex}.dropzone-minimal:hover .dropzone-svg-wrap{border-color:var(--text-secondary);color:var(--text-secondary)}.dropzone-text{color:var(--text-primary);font-size:.875rem;font-weight:600}.dropzone-subtext{color:var(--text-muted);font-size:.75rem}.dropzone-cta{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;border:1px solid var(--border-color);border-radius:20px;align-items:center;gap:.3rem;margin-top:.5rem;padding:.3rem .75rem;font-size:.72rem;font-weight:600;transition:all .2s;display:inline-flex}.dropzone-minimal:hover .dropzone-cta{border-color:var(--text-secondary);color:var(--text-primary)}.dropzone-has-images{pointer-events:none;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;width:100%;padding:1.25rem;display:flex}.dropzone-thumbs{flex-wrap:wrap;justify-content:center;gap:.5rem;display:flex}.dropzone-thumb{object-fit:cover;border:1.5px solid var(--border-color);width:72px;height:72px;box-shadow:var(--shadow-sm);border-radius:8px;transition:transform .2s}.dropzone-minimal:hover .dropzone-thumb{transform:scale(1.04)}.dropzone-has-meta{align-items:center;gap:.75rem;display:flex}.dropzone-count{color:var(--text-secondary);font-size:.8rem;font-weight:500}.dropzone-clear-btn{color:var(--text-muted);background:var(--bg-surface);border:1px solid var(--border-color);cursor:pointer;pointer-events:all;z-index:5;border-radius:6px;align-items:center;gap:.3rem;padding:.25rem .6rem;font-size:.75rem;font-weight:500;transition:all .2s;display:inline-flex;position:relative}.dropzone-clear-btn:hover{color:var(--error-text);border-color:var(--error-border);background:var(--error-bg)}.dropzone-add-more{color:var(--text-muted);letter-spacing:.01em;font-size:.72rem}.details-form{flex-direction:column;gap:1rem;display:flex}.details-form--stretch{flex:1}.description-field-wrap--stretch{flex-direction:column;flex:1;display:flex}.description-stretch{resize:none;flex:1;min-height:140px}.input-minimal{background:var(--bg-base);border:1px solid var(--border-color);width:100%;color:var(--text-primary);resize:vertical;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border-radius:10px;outline:none;padding:.85rem 1rem;font-size:.9rem;transition:all .3s}.input-minimal:focus{border-color:var(--accent);background:var(--bg-surface)}select.input-minimal{appearance:none;background-position:right .7em top 50%,0 0;background-repeat:no-repeat,repeat;background-size:.65em,100%}select.input-minimal option{background:var(--bg-surface);color:var(--text-primary)}.description-field-wrap{flex-direction:column;gap:.5rem;display:flex}.improve-desc-btn{color:#fff;cursor:pointer;letter-spacing:.02em;white-space:nowrap;background:linear-gradient(135deg,#8b5cf6 0%,#ec4899 50%,#f43f5e 100%) 0 0/200% 200%;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.5rem 1.25rem;font-size:.85rem;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1);animation:3s infinite bg-gradient-shift;display:inline-flex;box-shadow:0 4px 15px #ec48994d}.improve-desc-btn:hover:not(:disabled){background-size:250% 250%;transform:translateY(-2px)scale(1.02);box-shadow:0 6px 20px #ec489980}@keyframes bg-gradient-shift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}.improve-desc-btn:disabled{opacity:.4;cursor:not-allowed;color:var(--text-secondary);border:1px solid var(--border-color);box-shadow:none;background:0 0;animation:none;transform:none}.improve-spinner{border:1.5px solid var(--border-color);border-top-color:var(--text-secondary);border-radius:50%;flex-shrink:0;width:11px;height:11px;animation:.7s linear infinite improve-spin;display:inline-block}@keyframes improve-spin{to{transform:rotate(360deg)}}.improve-error{color:var(--error-text);background:var(--error-bg);border:1px solid var(--error-border);border-radius:6px;padding:.4rem .65rem;font-size:.75rem;animation:.2s fadeInUp}@keyframes fadeInUp{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.generation-footer{flex-direction:column;align-items:center;gap:1rem;margin-top:2rem;display:flex}.generate-huge-btn{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-hover) 100%);color:var(--accent-text);cursor:pointer;letter-spacing:-.01em;border:none;border-radius:12px;align-items:center;gap:.75rem;padding:1.25rem 3rem;font-size:1.15rem;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex;box-shadow:0 4px 15px #0000001a}.dark-theme .generate-huge-btn{box-shadow:0 8px 25px -5px #d9f95d66}.generate-huge-btn:hover{transform:translateY(-3px)scale(1.02);box-shadow:0 15px 30px -5px #0003}.dark-theme .generate-huge-btn:hover{box-shadow:0 15px 30px -5px #d9f95d80}.generate-huge-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.disclaimer-text{color:var(--text-muted);text-align:center;max-width:500px;font-size:.75rem}.error-message{background:var(--error-bg);color:var(--error-text);border:1px solid var(--error-border);text-align:center;border-radius:6px;margin-top:1rem;padding:.75rem 1rem;font-size:.875rem}.gallery-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.back-link{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:.5rem;padding:0;font-size:.875rem;font-weight:500;display:flex}.back-link:hover{color:var(--text-primary)}.status-indicator{color:var(--text-primary);font-size:1.125rem;font-weight:600}.status-animating{animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.gallery-actions{gap:.75rem;display:flex}.secondary-btn{background:var(--bg-surface-elevated);border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;border-radius:6px;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.secondary-btn:hover:not(:disabled){background:var(--border-color)}.secondary-btn:disabled{opacity:.5;cursor:not-allowed}.strategy-panel{background:var(--bg-surface);border:1px solid var(--border-color);color:var(--text-secondary);border-radius:8px;flex-direction:column;gap:.5rem;margin-bottom:2rem;padding:1.25rem;font-size:.875rem;display:flex}.strategy-panel strong{color:var(--text-primary);font-weight:500}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;display:grid}.image-card{background:var(--bg-surface);border:1px solid var(--border-color);box-shadow:var(--shadow-md);border-radius:16px;flex-direction:column;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s;display:flex;overflow:hidden}.image-card:hover{transform:translateY(-5px)}.image-aspect{aspect-ratio:1;background:var(--bg-base);border-bottom:1px solid var(--border-color);justify-content:center;align-items:center;display:flex;position:relative}.image-aspect img{object-fit:cover;width:100%;height:100%;transition:opacity .2s}.placeholder-text{color:var(--text-muted);font-size:.875rem}.overlay-actions{opacity:0;flex-direction:column;gap:.5rem;transition:opacity .2s;display:flex;position:absolute;top:.5rem;right:.5rem}.image-card:hover .overlay-actions{opacity:1}.icon-btn{background:var(--bg-surface);width:32px;height:32px;color:var(--text-primary);border:1px solid var(--border-color);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;transition:all .2s;display:flex}.icon-btn:hover{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.card-meta{flex-direction:column;gap:.5rem;padding:1.25rem;display:flex}.meta-badge{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);align-self:flex-start;font-size:.7rem;font-weight:600}.card-meta h4{color:var(--text-primary);font-size:1rem;font-weight:500}.card-meta p{color:var(--text-secondary);font-size:.875rem}.card-meta small{color:var(--text-muted);margin-top:.5rem;font-size:.75rem;line-height:1.4}.global-footer{text-align:center;color:var(--text-muted);border-top:1px solid var(--border-color);margin-top:4rem;padding:2rem;font-size:.75rem}.global-footer a{color:var(--text-secondary);text-decoration:none;transition:color .2s}.global-footer a:hover{color:var(--text-primary)}.legal-page{max-width:680px;margin:3rem auto 5rem;padding:0 1.5rem;line-height:1.7}.legal-header{border-bottom:1px solid var(--border-color);margin-bottom:3rem;padding-bottom:2rem}.legal-header h1{letter-spacing:-.02em;color:var(--text-primary);margin-bottom:.5rem;font-size:2.25rem;font-weight:700}.legal-header .legal-date{color:var(--text-muted);font-family:monospace;font-size:.875rem}.legal-page h2{color:var(--text-primary);border-bottom:1px solid var(--border-color);margin-top:2.5rem;margin-bottom:1rem;padding-bottom:.5rem;font-size:1.25rem;font-weight:600}.legal-page p{color:var(--text-secondary);margin-bottom:1.25rem;font-size:1rem}.legal-page ul{color:var(--text-secondary);margin-bottom:1.5rem;padding-left:1.5rem}.legal-page li{margin-bottom:.5rem;font-size:.95rem}.legal-page strong{color:var(--text-primary);font-weight:600}.header-left{align-items:center;gap:1.25rem;display:flex}.header-right{align-items:center;gap:.75rem;display:flex}.header-projects-btn{background:var(--accent);color:var(--accent-text);letter-spacing:.01em;cursor:pointer;white-space:nowrap;border:none;border-radius:999px;align-items:center;gap:.45rem;padding:.45rem 1rem;font-size:.8rem;font-weight:700;transition:all .25s cubic-bezier(.4,0,.2,1);display:inline-flex}.header-projects-btn:hover{background:var(--accent-hover)}.projects-page{max-width:1100px;margin:0 auto;padding:0 1.5rem 5rem}.projects-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:2.5rem;padding-top:1rem;display:flex}.projects-title{letter-spacing:-.02em;margin-bottom:.25rem;font-size:2rem;font-weight:700}.projects-subtitle{color:var(--text-muted);font-size:.875rem}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem;display:grid}.project-card{background:var(--bg-surface);border:1px solid var(--border-color);cursor:pointer;box-shadow:var(--shadow-md);border-radius:16px;transition:transform .25s cubic-bezier(.4,0,.2,1),box-shadow .25s,border-color .2s;overflow:hidden}.project-card:hover{border-color:var(--accent);transform:translateY(-4px)}.project-card-thumb{aspect-ratio:1;background:var(--bg-base);position:relative;overflow:hidden}.project-card-thumb img{object-fit:cover;width:100%;height:100%;transition:transform .3s;display:block}.project-card:hover .project-card-thumb img{transform:scale(1.04)}.project-card-thumb-empty{width:100%;height:100%;color:var(--text-muted);justify-content:center;align-items:center;font-size:2.5rem;display:flex}.project-card-overlay{opacity:0;background:#00000073;justify-content:center;align-items:center;transition:opacity .2s;display:flex;position:absolute;inset:0}.project-card:hover .project-card-overlay{opacity:1}.project-open-btn{background:var(--accent);color:var(--accent-text);letter-spacing:-.01em;border-radius:8px;padding:.55rem 1.25rem;font-size:.875rem;font-weight:600}.project-card-meta{flex-direction:column;gap:.4rem;padding:1rem 1.25rem 1.25rem;display:flex}.project-card-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:600;overflow:hidden}.project-card-details{flex-wrap:wrap;gap:.4rem;display:flex}.project-badge{text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);background:var(--bg-base);border:1px solid var(--border-color);white-space:nowrap;border-radius:4px;padding:.2rem .5rem;font-size:.7rem;font-weight:500}.project-card-date{color:var(--text-muted);margin-top:.15rem;font-size:.75rem}.projects-empty{text-align:center;padding:5rem 1rem}.projects-empty-icon{opacity:.4;margin-bottom:1.5rem;font-size:3rem}.projects-empty h3{color:var(--text-primary);margin-bottom:.5rem;font-size:1.25rem;font-weight:600}.projects-empty p{color:var(--text-secondary);max-width:360px;margin:0 auto;font-size:.9rem;line-height:1.6}.projects-loading-dots{justify-content:center;gap:6px;display:flex}.projects-loading-dots span{background:var(--accent);border-radius:50%;width:8px;height:8px;animation:1.4s ease-in-out infinite both dotPulse}.projects-loading-dots span:nth-child(2){animation-delay:.2s}.projects-loading-dots span:nth-child(3){animation-delay:.4s}@keyframes dotPulse{0%,80%,to{opacity:.4;transform:scale(0)}40%{opacity:1;transform:scale(1)}}.modal-backdrop{z-index:999;background:#000000b3;justify-content:center;align-items:flex-start;padding:2rem 1rem;animation:.2s fadeInBackdrop;display:flex;position:fixed;inset:0;overflow-y:auto}@keyframes fadeInBackdrop{0%{opacity:0}to{opacity:1}}.modal-panel{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:20px;width:100%;max-width:860px;padding:2rem 2rem 2.5rem;animation:.25s cubic-bezier(.4,0,.2,1) slideUpModal;position:relative}@keyframes slideUpModal{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-close-btn{background:var(--bg-base);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;font-size:.9rem;transition:all .2s;display:flex;position:absolute;top:1.25rem;right:1.25rem}.modal-close-btn:hover{color:var(--text-primary);border-color:var(--text-secondary)}.modal-header{margin-bottom:1.75rem;padding-right:2rem}.modal-title{letter-spacing:-.02em;margin-bottom:.6rem;font-size:1.5rem;font-weight:700}.modal-badges{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.75rem;display:flex}.modal-strategy-text{color:var(--text-secondary);margin-top:.5rem;font-size:.875rem;line-height:1.5}.modal-images-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;display:grid}.modal-image-card{border:1px solid var(--border-color);background:var(--bg-base);border-radius:12px;transition:transform .2s;overflow:hidden}.modal-image-card:hover{transform:translateY(-2px)}.modal-image{aspect-ratio:1;object-fit:cover;width:100%;display:block}.modal-image-meta{flex-direction:column;gap:.3rem;padding:.75rem;display:flex}.modal-image-headline{color:var(--text-secondary);margin-top:.2rem;font-size:.8rem;line-height:1.4}.modal-loading,.modal-error{text-align:center;color:var(--text-muted);padding:3rem;font-size:.9rem}.modal-error{color:var(--error-text)}.saved-toast{z-index:1000;background:var(--accent);color:var(--accent-text);white-space:nowrap;pointer-events:none;border-radius:100px;padding:.65rem 1.5rem;font-size:.875rem;font-weight:600;animation:.3s cubic-bezier(.4,0,.2,1) toastSlideUp,.3s 2.7s forwards toastFadeOut;position:fixed;bottom:2rem;left:50%;transform:translate(-50%)}@keyframes toastSlideUp{0%{opacity:0;transform:translate(-50%)translateY(16px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes toastFadeOut{0%{opacity:1}to{opacity:0}}.usage-badge{justify-content:center;animation:.3s fadeInDown;display:flex}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.usage-badge-pill{letter-spacing:.01em;border:1px solid var(--border-color);border-radius:100px;align-items:center;gap:.4rem;padding:.35rem .9rem;font-size:.78rem;font-weight:600;transition:all .2s;display:inline-flex}.usage-badge-ok{background:var(--bg-surface);color:var(--text-secondary)}.sparkle-icon{animation:2s ease-in-out infinite alternate sparkle-pulse}@keyframes sparkle-pulse{0%{opacity:.6;transform:scale(.9)}to{opacity:1;transform:scale(1.1)}}.usage-badge-low,.usage-badge-empty{background:var(--error-bg);color:var(--error-text);border-color:var(--error-border)}.usage-badge-unlimited{background:var(--bg-base);color:var(--text-muted);border-color:var(--border-color)}.form-section{margin-bottom:2rem}.label-row{justify-content:space-between;align-items:baseline;gap:.75rem;margin-bottom:.5rem;display:flex}.input-hint{color:var(--text-muted);letter-spacing:.01em;white-space:nowrap;opacity:.75;font-size:.68rem;font-weight:400}.selects-row{flex-wrap:wrap;align-items:flex-start;gap:1rem;display:flex}.error-message--icon{text-align:left;align-items:flex-start;gap:.5rem;display:flex}.error-icon{flex-shrink:0;font-size:.9rem;line-height:1.4}.status-done{color:var(--accent);font-weight:600}.status-generating-inner{align-items:center;gap:.6rem;display:flex}.status-spinner{border:2px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.secondary-btn--download{background:var(--accent);color:var(--accent-text);border-color:#0000;font-weight:600}.secondary-btn--download:hover:not(:disabled){background:var(--accent-hover)}.regenerating-overlay{color:#fff;letter-spacing:.01em;background:#00000073;justify-content:center;align-items:center;font-size:.8rem;font-weight:500;display:flex;position:absolute;inset:0}.project-download-btn{background:var(--bg-base);border:1px solid var(--border-color);width:calc(100% - 2rem);color:var(--text-secondary);letter-spacing:.01em;cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:.4rem;margin:0 1rem 1rem;padding:.55rem 1rem;font-size:.8rem;font-weight:600;transition:all .2s;display:flex}.project-download-btn:hover:not(:disabled){background:var(--accent);color:var(--accent-text);border-color:#0000}.project-download-btn:disabled{opacity:.6;cursor:not-allowed}.project-download-spinner{border:2px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;width:12px;height:12px;animation:.8s linear infinite spin;display:inline-block}.project-download-error{color:var(--error-text);margin-top:.25rem;font-size:.7rem}.project-version-badge{background:var(--bg-surface);color:var(--text-primary);letter-spacing:.04em;pointer-events:none;border:1px solid var(--border-color);border-radius:4px;padding:.15rem .5rem;font-size:.68rem;font-weight:700;position:absolute;top:.5rem;left:.5rem}.modal-header-top{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.6rem;display:flex}.modal-download-row{flex-wrap:wrap;align-items:center;gap:1rem;margin-top:1rem;display:flex}.modal-download-btn{background:var(--bg-base);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-radius:8px;align-items:center;gap:.4rem;padding:.55rem 1.25rem;font-size:.85rem;font-weight:600;transition:all .2s;display:inline-flex}.modal-download-btn:hover:not(:disabled){background:var(--accent);color:var(--accent-text);border-color:#0000}.modal-download-btn:disabled{opacity:.5;cursor:not-allowed}.modal-download-error{color:var(--error-text);font-size:.78rem}.version-nav{flex-shrink:0;align-items:center;gap:.4rem;display:flex}.version-nav-btn{background:var(--bg-base);border:1px solid var(--border-color);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;transition:all .2s;display:flex}.version-nav-btn:hover:not(:disabled){background:var(--bg-surface-elevated);color:var(--text-primary)}.version-nav-btn:disabled{opacity:.35;cursor:not-allowed}.version-nav-label{color:var(--text-secondary);white-space:nowrap;text-align:center;min-width:56px;font-size:.78rem;font-weight:600}.modal-image-wrap{position:relative;overflow:hidden}.modal-image-download-btn{background:var(--bg-surface);width:28px;height:28px;color:var(--text-primary);border:1px solid var(--border-color);cursor:pointer;opacity:0;border-radius:6px;justify-content:center;align-items:center;font-size:.8rem;transition:opacity .2s,background .2s;display:flex;position:absolute;bottom:.4rem;right:.4rem}.modal-image-card:hover .modal-image-download-btn{opacity:1}.modal-image-download-btn:hover{background:var(--accent);color:var(--accent-text);border-color:#0000}.gen-loading-root{justify-content:center;align-items:center;width:100%;padding:4rem 1rem;animation:.5s ease-out fadeIn;display:flex}.gen-loading-root--done{padding:2rem 1rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.gen-loading-layout{gap:2rem;width:100%;max-width:900px;display:flex}@media (width<=768px){.gen-loading-layout{flex-direction:column}}.gen-main-card{background:var(--bg-surface);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);border-radius:16px;flex:2;padding:3rem;position:relative;overflow:hidden}.gen-stage-badge{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:20px;margin-bottom:1.5rem;padding:.3rem .6rem;font-size:.75rem;font-weight:600;display:inline-block}.gen-stage-title{color:var(--text-primary);align-items:center;gap:.75rem;margin-bottom:.5rem;font-size:1.75rem;font-weight:700;display:flex}.gen-stage-pulse{background:var(--accent);border-radius:50%;width:10px;height:10px;animation:2s infinite genPulse;display:inline-block}@keyframes genPulse{0%,to{opacity:1}50%{opacity:.5}}.gen-stage-desc{color:var(--text-secondary);margin-bottom:3rem;font-size:1rem;line-height:1.5}.gen-progress-wrap{background:var(--bg-base);border-radius:2px;height:4px;margin-bottom:.75rem;overflow:hidden}.gen-progress-bar{background:var(--accent);height:100%}.gen-progress-row{color:var(--text-muted);justify-content:space-between;margin-bottom:3rem;font-size:.85rem;display:flex}.gen-progress-time{font-variant-numeric:tabular-nums}.gen-message-box{background:var(--bg-base);border-left:3px solid var(--accent);border-radius:8px;align-items:center;gap:.75rem;padding:1rem 1.25rem;display:flex}.gen-message-dot{background:var(--text-muted);border-radius:50%;width:6px;height:6px}.gen-message-text{color:var(--text-primary);font-size:.9rem;animation:.4s ease-out fadeSlide}@keyframes fadeSlide{0%{opacity:0;transform:translate(5px)}to{opacity:1;transform:translate(0)}}.gen-side-panel{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:16px;flex-direction:column;flex:1;padding:2rem;display:flex;position:relative;overflow:hidden}.gen-side-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:1.5rem;font-size:.85rem;font-weight:600}.gen-checklist{flex-direction:column;gap:1rem;display:flex}.gen-check-item{color:var(--text-muted);align-items:center;gap:.75rem;font-size:.9rem;transition:color .3s;display:flex}.gen-check-item--active{color:var(--text-primary);font-weight:500}.gen-check-item--done{color:var(--text-secondary)}.gen-check-icon{text-align:center;width:1.2rem;font-size:1rem}.gen-check-item--done .gen-check-icon{color:var(--accent)}.gen-check-item--active .gen-check-icon{animation:2s infinite gentlePulse}@keyframes gentlePulse{0%,to{opacity:1}50%{opacity:.5}}.gen-success-card,.gen-error-card{text-align:center;background:var(--bg-surface);border:1px solid var(--border-color);box-shadow:var(--shadow-md);border-radius:16px;max-width:500px;margin:0 auto;padding:3rem}.gen-success-icon{background:var(--bg-base);width:64px;height:64px;color:var(--accent);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 1.5rem;font-size:2rem;display:flex}.gen-error-icon{background:var(--error-bg);width:64px;height:64px;color:var(--error-text);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 1.5rem;font-size:2rem;display:flex}.gen-success-title,.gen-error-title{color:var(--text-primary);margin-bottom:.75rem;font-size:1.5rem;font-weight:600}.gen-success-sub,.gen-error-sub{color:var(--text-secondary);font-size:1rem}.gen-error-sub{margin-bottom:2rem}.gen-error-retry-btn{border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;background:0 0;border-radius:8px;padding:.75rem 1.5rem;font-weight:500;transition:all .2s}.gen-error-retry-btn:hover{background:var(--bg-base);border-color:var(--text-secondary)}.description-main{font-size:.95rem;line-height:1.6}.improve-desc-hint-row{align-items:center;gap:.6rem;margin-top:.25rem;display:flex}.improve-desc-hint{color:var(--text-muted);font-size:.8rem}.form-fields-row{flex-wrap:wrap;gap:1rem;display:flex}.form-field-group{flex-direction:column;flex:1;gap:.3rem;min-width:140px;display:flex}.field-hint{color:var(--text-muted);font-size:.72rem;line-height:1.4}.aurora-bg{background-color:var(--bg-base);z-index:0;position:absolute;inset:0;overflow:hidden}.aurora-blob{filter:blur(100px);opacity:.2;border-radius:50%;animation:25s ease-in-out infinite alternate auroraWarp;position:absolute}.aurora-1{background:var(--accent);width:60vw;height:60vh;top:-10%;left:-10%}.aurora-2{background:var(--text-muted);width:80vw;height:80vh;bottom:-20%;right:-10%}@keyframes auroraWarp{0%{transform:scale(1)translate(0)rotate(0)}to{transform:scale(1.1)translate(2vw,2vh)rotate(5deg)}}.auth-page-wrapper{background-color:var(--bg-base);z-index:100;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.auth-back-btn{background:var(--bg-surface);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;border-radius:8px;align-items:center;gap:.5rem;padding:.5rem 1rem;transition:all .2s;display:flex;position:absolute;top:2rem;left:2rem}.auth-back-btn:hover{background:var(--bg-surface-elevated);color:var(--text-primary)}.auth-container{background:var(--bg-surface);border:1px solid var(--border-color);width:100%;max-width:480px;box-shadow:var(--shadow-lg);border-radius:24px;flex-direction:column;gap:2rem;padding:3rem;display:flex}.auth-header{text-align:center}.auth-logo-wrapper{cursor:pointer;justify-content:center;margin-bottom:2rem;display:flex}.auth-title{color:var(--text-primary);margin-bottom:.5rem;font-size:2rem;font-weight:700}.auth-subtitle{color:var(--text-muted);font-size:.95rem;line-height:1.5}.auth-form{flex-direction:column;gap:1.25rem;display:flex}.auth-input-group{flex-direction:column;gap:.5rem;display:flex}.auth-input-group label{color:var(--text-secondary);margin-left:.25rem;font-size:.85rem;font-weight:500}.auth-input-group input{background:var(--bg-surface-elevated);border:1px solid var(--border-color);color:var(--text-primary);border-radius:12px;padding:.875rem 1rem;font-size:1rem;transition:all .2s}.auth-input-group input:focus{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent);background:var(--bg-surface);outline:none}.auth-submit-btn{background:var(--accent);color:var(--accent-text);cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;height:54px;margin-top:.5rem;padding:1rem;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.auth-submit-btn:hover{background:var(--accent-hover);transform:translateY(-1px)}.auth-submit-btn:active{transform:translateY(1px)}.auth-error{color:#ef4444;background:#ef44441a;border:1px solid #ef444433;border-radius:12px;align-items:center;gap:.5rem;padding:.875rem 1rem;font-size:.875rem;display:flex}.auth-divider{text-align:center;color:var(--text-muted);align-items:center;font-size:.85rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";border-bottom:1px solid #ffffff1a;flex:1}.auth-divider:not(:empty):before{margin-right:.5em}.auth-divider:not(:empty):after{margin-left:.5em}.auth-google-btn{color:var(--text-primary);cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;justify-content:center;align-items:center;gap:.75rem;padding:.875rem;font-size:1rem;font-weight:500;transition:all .2s;display:flex}.auth-google-btn:hover{background:#ffffff1a}.auth-footer-text{text-align:center;color:var(--text-muted);font-size:.9rem}.auth-footer-text button{color:var(--text-primary);cursor:pointer;background:0 0;border:none;padding:0 .25rem;font-weight:500;text-decoration:underline}.auth-spinner{border:2px solid #0003;border-top-color:#000;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}.top-corner-btn{background:var(--bg-surface);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border-color);cursor:pointer;color:var(--text-secondary);box-shadow:var(--shadow-sm);border-radius:999px;align-items:center;gap:8px;padding:8px 16px;font-size:.85rem;font-weight:500;transition:all .2s;display:flex}.top-corner-btn:hover{background:var(--bg-surface-elevated);color:var(--text-primary);border-color:var(--text-primary);transform:translateY(-1px)}@keyframes highlightGlow{0%{box-shadow:0 0 0px var(--accent);border-color:var(--border-color)}50%{box-shadow:0 0 15px var(--accent);border-color:var(--accent)}to{border-color:var(--border-color);box-shadow:0 0 #0000}}.highlight-glow{animation:1s ease-in-out highlightGlow}.paywall-modal .badge{color:var(--accent);text-transform:uppercase;letter-spacing:.05em;background:#21de6b1a;border:1px solid #21de6b33;border-radius:99px;padding:.25rem .75rem;font-size:.8rem;font-weight:600}.paywall-modal .auth-header{margin-bottom:1.5rem}.paywall-features li{color:var(--text-secondary)}.under-form-teaser{margin:1rem auto 0;transition:all .2s}.quiet-teaser:hover{border-color:#fff3!important}.active-teaser{box-shadow:0 4px 20px #21de6b1a}@media (width<=768px){.app-header{padding:1rem}.top-corner-btn{display:none!important}.manual-inputs{flex-direction:column;gap:1.5rem}.manual-inputs .manual-col:first-child,.manual-inputs .manual-col:last-child{flex:auto;width:100%}.url-bar{flex-direction:column}.url-bar .primary-btn{width:100%;padding:1rem}.details-form{gap:1.25rem}.mobile-sticky-cta{background:var(--bg-surface);border-top:1px solid var(--border-color);padding:1rem;padding-bottom:calc(1rem + env(safe-area-inset-bottom,20px));z-index:100;text-align:center;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -10px 25px #0000004d}.main-content{padding-bottom:120px!important}.auth-modal-content,.paywall-modal-premium{max-width:100%!important;padding-bottom:calc(2rem + env(safe-area-inset-bottom,20px))!important;border-radius:28px 28px 0 0!important;margin:0!important;position:fixed!important;bottom:0!important;left:0!important;right:0!important;transform:translateY(100%)scale(1)!important}.auth-modal-content.visible,.paywall-modal-premium.visible{transform:translateY(0)scale(1)!important}.result-carousel{scroll-snap-type:x mandatory;scrollbar-width:none;-webkit-overflow-scrolling:touch;gap:1rem;margin:0 -1.5rem;padding:.5rem 1rem 1.5rem;display:flex;overflow-x:auto}.result-carousel::-webkit-scrollbar{display:none}.result-carousel>div{scroll-snap-align:center;flex:0 0 85%}.result-grid-fallback{flex-direction:column;gap:1.5rem;display:flex}}.desktop-only-text{display:block}.mobile-only-text{display:none}@media (width<=768px){.desktop-only-text{display:none!important}.mobile-only-text{display:block!important}.mobile-stack-grid{flex-direction:column!important;gap:1.5rem!important;padding:0!important;display:flex!important}.hide-on-mobile{display:none!important}.gallery-header{flex-direction:column!important;align-items:flex-start!important;gap:1rem!important}}*{box-sizing:border-box}@media (width<=768px){.command-center{padding:1.25rem!important}.result-carousel{margin:0 -1.25rem!important;padding:0 1.25rem 2rem!important}.command-center{border-left:none!important;border-right:none!important;border-radius:0!important;width:100%!important;margin:0!important;padding:1.25rem!important}.mobile-bleed{border-left:none!important;border-right:none!important;border-radius:0!important;width:100vw!important;margin-left:calc(50% - 50vw)!important;margin-right:calc(50% - 50vw)!important;padding-left:1.25rem!important;padding-right:1.25rem!important}}.top-corner-btn{background:var(--bg-surface-elevated);color:var(--text-primary);border:1px solid var(--border-color);cursor:pointer;box-shadow:var(--shadow-sm);border-radius:8px;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.9rem;font-weight:500;transition:all .2s;display:flex}.top-corner-btn:hover{background:var(--bg-surface-hover);border-color:var(--accent)}.hidden{display:none}@media (width>=640px){.sm\\:inline{display:inline!important}}.custom-select-container{width:100%;position:relative}.custom-select-trigger{background:var(--bg-surface);border:1px solid var(--border-color);width:100%;height:48px;color:var(--text-primary);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:8px;justify-content:space-between;align-items:center;padding:0 1rem;font-family:inherit;font-size:.95rem;transition:all .2s;display:flex}.custom-select-trigger:hover{border-color:var(--accent);background:var(--bg-surface-elevated)}.custom-select-trigger.open{border-color:var(--accent);background:var(--bg-surface-elevated);box-shadow:0 0 0 3px #c6f1201a}.custom-select-value{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.custom-select-arrow{color:var(--text-secondary);flex-shrink:0;margin-left:8px;transition:transform .2s}.custom-select-arrow.open{transform:rotate(180deg)}.custom-select-dropdown{background:var(--bg-surface);border:1px solid var(--border-color);width:100%;box-shadow:var(--shadow-lg);z-index:100;border-radius:12px;padding:4px;animation:.15s ease-out dropdownFade;position:absolute;top:calc(100% + 8px);left:0;overflow:hidden}@keyframes dropdownFade{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.custom-select-option{color:var(--text-primary);cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:2px;padding:.75rem 1rem;font-size:.95rem;transition:all .15s;display:flex}.custom-select-option:last-child{margin-bottom:0}.custom-select-option:hover{background:var(--bg-surface-elevated)}.custom-select-option.selected{color:var(--accent);background:#c6f1201a;font-weight:500}.custom-select-check{color:var(--accent);flex-shrink:0;margin-left:8px}
