.gallery-page{min-height:calc(100vh - 56px)}.hero{position:relative;padding:var(--space-20) var(--space-6) var(--space-16);text-align:center;overflow:hidden}.hero-content{position:relative;z-index:2;max-width:700px;margin:0 auto}.hero-title{font-size:48px;font-weight:800;line-height:1.1;letter-spacing:-1.5px;color:var(--text-primary);margin-bottom:var(--space-4)}.hero-accent{background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:18px;color:var(--text-secondary);margin-bottom:var(--space-8);line-height:1.6;max-width:520px;margin-left:auto;margin-right:auto}.hero-cta{display:inline-flex;align-items:center;gap:var(--space-2);background:var(--accent);color:var(--bg-primary);border:none;padding:14px 28px;border-radius:var(--radius-md);font-size:16px;font-weight:700;cursor:pointer;transition:all var(--transition-base);position:relative}.hero-cta:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-glow)}.hero-cta:active{background:var(--accent-active);transform:translateY(0);box-shadow:none}.hero-cta:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.hero-cta:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.hero-visual{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none}.hero-glow{position:absolute;top:40%;left:50%;transform:translate(-50%,-50%);width:700px;height:700px;background:radial-gradient(ellipse at center,rgba(0,255,136,.07) 0%,rgba(0,212,255,.03) 40%,transparent 70%);border-radius:50%;animation:heroGlowPulse 6s ease-in-out infinite}@keyframes heroGlowPulse{0%,to{opacity:1;transform:translate(-50%,-50%) scale(1)}50%{opacity:.7;transform:translate(-50%,-50%) scale(1.05)}}.gallery-section{padding:var(--space-10) var(--space-6);max-width:1200px;margin:0 auto}.section-header{margin-bottom:var(--space-6)}.section-header h2{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-1)}.section-desc{color:var(--text-muted);font-size:14px}.experience-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-5)}.featured-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.experience-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:border-color var(--transition-base),transform var(--transition-base),box-shadow var(--transition-base);text-align:left;padding:0;width:100%;font-family:inherit}.experience-card:hover{border-color:#0f86;transform:translateY(-3px);box-shadow:0 12px 32px #0000004d,0 0 0 1px #00ff881a}.experience-card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.experience-card:active{transform:translateY(-1px)}.experience-card.featured{border-color:#00ff8826}.experience-card.featured:hover{border-color:#00ff8880}.card-thumbnail{aspect-ratio:16/10;background:var(--bg-primary);overflow:hidden;position:relative}.card-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.experience-card:hover .card-thumbnail img{transform:scale(1.03)}.card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-surface) 100%);position:relative;overflow:hidden}.card-placeholder:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 50%,rgba(0,255,136,.04),transparent 60%)}.card-live-preview{width:100%;height:100%;position:relative;overflow:hidden;background:#000}.card-live-preview iframe{width:300%;height:300%;border:none;transform:scale(.333);transform-origin:top left;pointer-events:none}.card-preview-overlay{position:absolute;top:0;right:0;bottom:0;left:0;cursor:pointer}.card-info{padding:var(--space-3) var(--space-4)}.card-title{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card-meta{display:flex;align-items:center;justify-content:space-between;font-size:13px;color:var(--text-muted)}.card-creator{display:flex;align-items:center;gap:6px}.card-avatar{width:18px;height:18px;border-radius:var(--radius-full)}.card-views{display:flex;align-items:center;gap:4px}.loading-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-5)}.experience-card.skeleton{height:260px;background:var(--bg-surface);position:relative;overflow:hidden;border:1px solid var(--border);cursor:default}.experience-card.skeleton:before{content:"";position:absolute;top:0;left:0;right:0;height:62%;background:var(--bg-primary)}.experience-card.skeleton:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.02) 50%,transparent 100%);animation:shimmer 1.8s ease-in-out infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.empty-gallery{text-align:center;padding:var(--space-16) var(--space-5);color:var(--text-muted)}.empty-gallery>svg{opacity:.3}.empty-gallery h3{font-size:20px;margin:var(--space-4) 0 var(--space-2);color:var(--text-secondary)}.empty-gallery p{margin-bottom:var(--space-6);color:var(--text-muted)}.cta-banner{text-align:center;padding:var(--space-16) var(--space-6);background:linear-gradient(to bottom,transparent,rgba(0,255,136,.03));border-top:1px solid var(--border);margin-top:var(--space-10)}.cta-banner h2{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-2)}.cta-banner p{color:var(--text-secondary);margin-bottom:var(--space-6);font-size:16px;max-width:480px;margin-left:auto;margin-right:auto}@media (max-width: 768px){.hero{padding:var(--space-12) var(--space-4) var(--space-10)}.hero-title{font-size:32px;letter-spacing:-1px}.hero-subtitle{font-size:16px}.hero-glow{width:400px;height:400px}.gallery-section{padding:var(--space-6) var(--space-4)}.experience-grid,.featured-grid,.loading-grid{grid-template-columns:1fr}.cta-banner{padding:var(--space-10) var(--space-4)}.cta-banner h2{font-size:22px}.cta-banner p{margin-bottom:var(--space-6)}}@media (max-width: 480px){.hero-title{font-size:28px}.hero-cta{width:100%;justify-content:center}}.simulator{flex:1;width:100%;height:100%;background:var(--bg-primary);position:relative;overflow:hidden;min-height:0;display:flex;flex-direction:column}.simulator-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-surface) 100%)}.placeholder-content{text-align:center;padding:var(--space-10);max-width:400px}.placeholder-icon{font-size:56px;margin-bottom:var(--space-6);display:block;opacity:.7;filter:grayscale(.2)}.placeholder-content h3{font-size:20px;font-weight:600;margin-bottom:var(--space-2);color:var(--text-primary)}.placeholder-content p{font-size:14px;color:var(--text-secondary);margin-bottom:var(--space-6);line-height:1.5}.placeholder-features{display:flex;gap:var(--space-3);justify-content:center;flex-wrap:wrap}.placeholder-features span{font-size:12px;color:var(--text-secondary);background:var(--bg-tertiary);padding:6px var(--space-3);border-radius:var(--radius-full);border:1px solid var(--border)}.spinner{display:inline-block;width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:simulatorSpin .8s linear infinite;margin:0 auto var(--space-4)}@keyframes simulatorSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}iframe{flex:1;width:100%;height:100%;border:none;display:block}.beta-gate{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 56px);padding:var(--space-6);background:radial-gradient(ellipse at center,rgba(0,255,136,.04) 0%,transparent 60%)}.beta-content{text-align:center;max-width:480px}.beta-badge{display:inline-block;padding:4px 12px;background:var(--accent-dim);color:var(--accent);font-size:12px;font-weight:700;letter-spacing:1.5px;border-radius:var(--radius-full);border:1px solid rgba(0,255,136,.2);margin-bottom:var(--space-5)}.beta-content h1{font-size:32px;font-weight:800;color:var(--text-primary);margin-bottom:var(--space-3);letter-spacing:-.5px}.beta-content>p{color:var(--text-secondary);font-size:16px;line-height:1.6;margin-bottom:var(--space-8)}.beta-cta{display:inline-flex;align-items:center;gap:var(--space-2);background:var(--accent);color:var(--bg-primary);border:none;padding:14px 28px;border-radius:var(--radius-md);font-size:16px;font-weight:700;cursor:pointer;transition:all var(--transition-base)}.beta-cta:hover{background:var(--accent-hover);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.beta-error{background:#ff44441a;border:1px solid rgba(255,68,68,.3);color:#f66;padding:10px 16px;border-radius:var(--radius-md);font-size:14px;margin-bottom:var(--space-4)}.invite-form{display:flex;gap:var(--space-2);margin-bottom:var(--space-6);max-width:380px;margin-left:auto;margin-right:auto}.invite-form input{flex:1;background:var(--bg-surface);border:1px solid var(--border);color:var(--text-primary);padding:12px 16px;border-radius:var(--radius-md);font-size:15px;font-family:var(--font-mono);letter-spacing:1px}.invite-form input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.invite-form .beta-cta{padding:12px 20px;font-size:14px;white-space:nowrap}.beta-invite-note{display:flex;align-items:center;justify-content:center;gap:var(--space-2);color:var(--text-muted);font-size:14px;margin-top:var(--space-6)}.beta-invite-note a{color:var(--accent);font-weight:500}.create-page{display:flex;height:calc(100vh - 56px);overflow:hidden;flex-wrap:wrap}.waitlist-banner{width:100%;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);background:#ffb80014;border-bottom:1px solid rgba(255,184,0,.15);color:var(--warning);font-size:14px}.waitlist-banner strong{display:block;margin-bottom:2px}.waitlist-banner p{font-size:13px;color:var(--text-secondary);margin:0}.prompt-sidebar{width:320px;min-width:280px;background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto}.prompt-section{padding:var(--space-4);border-bottom:1px solid var(--border)}.prompt-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.prompt-header h3{font-size:16px;font-weight:600;color:var(--text-primary)}.mode-toggle{display:flex;gap:2px;background:var(--bg-primary);border-radius:var(--radius-sm);padding:2px}.mode-toggle button{background:none;border:none;color:var(--text-muted);padding:5px 12px;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.mode-toggle button:hover:not(.active){color:var(--text-secondary)}.mode-toggle button.active{background:var(--accent);color:var(--bg-primary)}.prompt-section textarea{width:100%;background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);padding:var(--space-3);border-radius:var(--radius-md);font-size:14px;font-family:inherit;resize:vertical;min-height:80px;line-height:1.5;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.prompt-section textarea::placeholder{color:var(--text-muted)}.prompt-section textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.prompt-section textarea:disabled{opacity:.5;cursor:not-allowed}.generate-btn{width:100%;margin-top:var(--space-3);display:flex;align-items:center;justify-content:center;gap:var(--space-2);background:var(--accent);color:var(--bg-primary);border:none;padding:var(--space-3);border-radius:var(--radius-md);font-size:15px;font-weight:700;cursor:pointer;transition:all var(--transition-fast)}.generate-btn:hover:not(:disabled){background:var(--accent-hover);box-shadow:var(--shadow-glow)}.generate-btn:active:not(:disabled){background:var(--accent-active);transform:scale(.98);box-shadow:none}.generate-btn:disabled{opacity:.4;cursor:not-allowed}.spin{animation:spin 1s linear infinite}.rate-limit-info{text-align:center;font-size:12px;color:var(--text-muted);margin-top:var(--space-2)}.examples-section{padding:var(--space-4);border-bottom:1px solid var(--border)}.examples-section h4{font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-3);text-transform:uppercase;letter-spacing:.5px}.example-chips{display:flex;flex-wrap:wrap;gap:var(--space-2)}.example-chip{background:var(--bg-primary);border:1px solid var(--border);color:var(--text-secondary);padding:7px 12px;border-radius:var(--radius-full);font-size:12px;cursor:pointer;transition:all var(--transition-fast);text-align:left;line-height:1.3}.example-chip:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.example-chip:disabled{opacity:.3;cursor:not-allowed}.history-section{padding:var(--space-4);flex:1;overflow-y:auto}.history-section h4{font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-3);text-transform:uppercase;letter-spacing:.5px}.history-list{display:flex;flex-direction:column;gap:2px}.history-item{display:flex;align-items:center;gap:var(--space-2);background:none;border:none;color:var(--text-secondary);padding:8px var(--space-2);border-radius:var(--radius-sm);font-size:12px;cursor:pointer;text-align:left;width:100%;transition:all var(--transition-fast)}.history-item:hover{background:var(--bg-hover);color:var(--text-primary)}.history-item:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.history-prompt{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.workspace{flex:1;display:flex;flex-direction:column;min-width:0}.workspace-toolbar{display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-4);height:44px;background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0}.toolbar-left{flex:1}.project-title-input{background:none;border:1px solid transparent;color:var(--text-primary);font-size:14px;font-weight:500;padding:5px var(--space-2);border-radius:var(--radius-sm);width:200px;transition:all var(--transition-fast)}.project-title-input::placeholder{color:var(--text-muted)}.project-title-input:hover{border-color:var(--border)}.project-title-input:focus{outline:none;background:var(--bg-primary);border-color:var(--border)}.toolbar-center{display:flex;gap:2px;background:var(--bg-primary);border-radius:var(--radius-sm);padding:2px}.tab-btn{display:flex;align-items:center;gap:4px;background:none;border:none;color:var(--text-muted);padding:6px 14px;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.tab-btn:hover:not(.active){color:var(--text-secondary)}.tab-btn.active{background:var(--bg-surface);color:var(--text-primary);box-shadow:var(--shadow-sm)}.toolbar-right{display:flex;gap:var(--space-2);flex:1;justify-content:flex-end}.tool-btn{display:flex;align-items:center;gap:4px;background:none;border:1px solid var(--border);color:var(--text-secondary);padding:5px 12px;border-radius:var(--radius-sm);font-size:13px;cursor:pointer;transition:all var(--transition-fast);min-height:32px}.tool-btn:hover{border-color:var(--text-secondary);color:var(--text-primary);background:var(--bg-hover)}.share-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.workspace-content{flex:1;display:flex;overflow:hidden;position:relative}.workspace-content.advanced{flex-direction:row}.code-pane{width:50%;min-width:300px;height:100%;display:flex;flex-direction:column;border-right:1px solid var(--border)}.preview-pane{flex:1;position:relative;background:var(--bg-primary);display:flex;flex-direction:column;min-height:0}.workspace-content.simple .preview-pane{width:100%}.rating-bar{position:absolute;bottom:48px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-2);background:#0a0a0fd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:8px 16px;border-radius:var(--radius-full);border:1px solid var(--border);z-index:10;animation:ratingFadeIn .3s ease-out}@keyframes ratingFadeIn{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.rating-label{font-size:12px;color:var(--text-muted);margin-right:var(--space-1)}.rate-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:6px;border-radius:var(--radius-sm);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.rate-btn:hover:not(:disabled){color:var(--accent);background:var(--accent-dim)}.rate-btn.active{color:var(--accent)}.rate-btn:disabled:not(.active){opacity:.3;cursor:default}.error-banner{position:absolute;top:var(--space-2);left:var(--space-2);right:var(--space-2);display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);background:#ff44661f;border:1px solid rgba(255,68,102,.25);color:#f89;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:13px;z-index:10;animation:errorSlideDown .2s ease-out}@keyframes errorSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.error-banner span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.fix-btn{display:flex;align-items:center;gap:4px;background:#ff446626;border:1px solid rgba(255,68,102,.25);color:#fab;padding:5px 12px;border-radius:var(--radius-sm);font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all var(--transition-fast)}.fix-btn:hover:not(:disabled){background:#ff446640;color:#fcd}.fix-btn:disabled{opacity:.4;cursor:not-allowed}.status-bar{display:flex;align-items:center;gap:var(--space-2);padding:0 var(--space-4);height:26px;background:var(--bg-surface);border-top:1px solid var(--border);font-size:11px;color:var(--text-muted);flex-shrink:0}.status-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0}.status-dot.ready{background:var(--accent)}.status-dot.error,.status-dot.runtime-error{background:var(--error)}.status-dot.generating,.status-dot.iterating,.status-dot.fixing{background:var(--warning);animation:statusPulse 1.2s ease-in-out infinite}@keyframes statusPulse{0%,to{opacity:1;box-shadow:0 0 #ffb80066}50%{opacity:.6;box-shadow:0 0 6px 2px #ffb80033}}.status-meta{margin-left:auto;font-family:var(--font-mono);font-size:10px;letter-spacing:.3px}@media (max-width: 768px){.create-page{flex-direction:column}.prompt-sidebar{width:100%;min-width:0;max-height:35vh;border-right:none;border-bottom:1px solid var(--border)}.workspace-content.advanced{flex-direction:column}.code-pane{width:100%;min-width:0;height:40%;border-right:none;border-bottom:1px solid var(--border)}.toolbar-left{display:none}.project-title-input{width:100%}.rating-bar{bottom:36px;padding:6px 12px}}.viewer-page{height:calc(100vh - 56px);display:flex;flex-direction:column;background:var(--bg-primary)}.viewer-page.loading,.viewer-page.error{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:var(--space-4);text-align:center;color:var(--text-secondary);padding:var(--space-6)}.viewer-page.error h2{font-size:22px;font-weight:700;color:var(--text-primary)}.viewer-page.error p{max-width:400px;line-height:1.5;margin-bottom:var(--space-2)}.viewer-loader{display:flex;align-items:center;gap:var(--space-3);font-size:15px;color:var(--text-secondary)}.viewer-loader:before{content:"";width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.viewer-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-4);background:#0a0a0fd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);z-index:10;min-height:48px}.back-btn{display:flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-secondary);font-size:13px;cursor:pointer;padding:8px 12px;border-radius:var(--radius-sm);transition:all var(--transition-fast);min-height:36px}.back-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.viewer-info{text-align:center;min-width:0;flex:1;padding:0 var(--space-3)}.viewer-info h2{font-size:15px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.viewer-meta{display:inline-flex;align-items:center;gap:var(--space-2);font-size:12px;color:var(--text-muted)}.viewer-actions{display:flex;gap:var(--space-2);flex-shrink:0}.hero-cta.small{padding:7px 16px;font-size:13px;border-radius:var(--radius-md)}.viewer-iframe{flex:1;width:100%;border:none;background:var(--bg-primary)}@media (max-width: 768px){.viewer-header{flex-wrap:wrap;gap:var(--space-2);padding:var(--space-2) var(--space-3)}.viewer-info{order:-1;width:100%;text-align:left;padding:var(--space-1) 0}.viewer-actions{flex:1;justify-content:flex-end}.hero-cta.small{padding:7px 12px;font-size:12px}}.header{display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);height:56px;background:#12121ad9;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}.header-left{display:flex;align-items:center}.logo{display:flex;align-items:center;gap:var(--space-2);text-decoration:none;color:var(--text-primary);font-weight:700;font-size:18px;transition:opacity var(--transition-fast)}.logo:hover{text-decoration:none;opacity:.85}.logo-icon{color:var(--accent);font-size:22px;line-height:1}.logo-text{letter-spacing:-.5px}.header-nav{display:flex;align-items:center;gap:var(--space-1)}.nav-btn{background:none;border:none;color:var(--text-secondary);padding:8px var(--space-4);border-radius:var(--radius-md);font-size:14px;cursor:pointer;transition:all var(--transition-fast);font-weight:500;min-height:36px}.nav-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-btn.active{color:var(--text-primary);background:var(--bg-hover)}.nav-btn.create-btn{display:flex;align-items:center;gap:6px;background:var(--accent);color:var(--bg-primary);font-weight:600;padding:8px 16px}.nav-btn.create-btn:hover{background:var(--accent-hover);color:var(--bg-primary);box-shadow:var(--shadow-glow)}.nav-btn.create-btn:active{background:var(--accent-active);box-shadow:none}.header-right{display:flex;align-items:center;gap:var(--space-3)}.sign-in-btn{display:flex;align-items:center;gap:6px;background:none;border:1px solid var(--border);color:var(--text-primary);padding:7px var(--space-4);border-radius:var(--radius-md);font-size:14px;cursor:pointer;transition:all var(--transition-fast);min-height:36px}.sign-in-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.user-menu-wrapper{position:relative}.user-btn{display:flex;align-items:center;gap:var(--space-2);background:none;border:1px solid transparent;color:var(--text-primary);cursor:pointer;padding:4px var(--space-2);border-radius:var(--radius-md);transition:all var(--transition-fast);min-height:36px}.user-btn:hover{background:var(--bg-hover);border-color:var(--border)}.user-avatar{width:28px;height:28px;border-radius:var(--radius-full);border:1px solid var(--border)}.user-name{font-size:14px;font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-dropdown{position:absolute;top:calc(100% + 4px);right:0;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-1);min-width:180px;box-shadow:var(--shadow-lg);z-index:200;animation:dropdownIn .15s ease-out}@keyframes dropdownIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.user-dropdown button{display:flex;align-items:center;gap:var(--space-2);width:100%;background:none;border:none;color:var(--text-primary);padding:10px var(--space-3);border-radius:var(--radius-sm);font-size:14px;cursor:pointer;text-align:left;transition:background var(--transition-fast)}.user-dropdown button:hover{background:var(--bg-hover)}.mobile-menu-btn{display:none;background:none;border:none;color:var(--text-primary);cursor:pointer;padding:8px;border-radius:var(--radius-sm);min-height:44px;min-width:44px;align-items:center;justify-content:center}.mobile-menu-btn:hover{background:var(--bg-hover)}.mobile-menu{display:none;position:fixed;top:56px;left:0;right:0;background:var(--bg-surface);border-bottom:1px solid var(--border);padding:var(--space-2);z-index:99;box-shadow:var(--shadow-lg);animation:mobileMenuIn .2s ease-out}@keyframes mobileMenuIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.mobile-menu button{display:block;width:100%;text-align:left;background:none;border:none;color:var(--text-primary);padding:var(--space-3) var(--space-4);font-size:16px;cursor:pointer;border-radius:var(--radius-md);min-height:44px;transition:background var(--transition-fast)}.mobile-menu button:hover{background:var(--bg-hover)}@media (max-width: 768px){.header-nav,.sign-in-btn .user-name{display:none}.mobile-menu-btn{display:flex}.mobile-menu{display:block}.user-name{display:none}.header{padding:0 var(--space-4)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:300;animation:overlayFadeIn .15s ease-out;padding:var(--space-4)}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);max-width:460px;width:100%;position:relative;animation:modalScaleIn .2s ease-out;box-shadow:var(--shadow-lg)}@keyframes modalScaleIn{0%{transform:scale(.95) translateY(8px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.modal-close{position:absolute;top:var(--space-3);right:var(--space-3);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-sm);min-height:36px;min-width:36px;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.modal-close:hover{color:var(--text-primary);background:var(--bg-hover)}.modal-body{padding:var(--space-8)}.modal-body h2{font-size:20px;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-2)}.modal-body>p{color:var(--text-secondary);font-size:14px;margin-bottom:var(--space-6);line-height:1.5}.auth-modal{text-align:center}.google-btn{display:inline-flex;align-items:center;gap:var(--space-3);background:#fff;color:#333;border:none;padding:var(--space-3) var(--space-6);border-radius:var(--radius-md);font-size:15px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);min-height:44px}.google-btn:hover{background:#f5f5f5;box-shadow:0 2px 12px #00000040}.google-btn:active{background:#e8e8e8;transform:scale(.98)}.google-btn:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.share-modal{max-width:480px}.share-title{font-weight:600;color:var(--text-primary)!important;font-size:16px!important;margin-bottom:var(--space-4)!important}.share-url-box{display:flex;gap:var(--space-2);margin-bottom:var(--space-6)}.share-url-box input{flex:1;background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);padding:10px var(--space-3);border-radius:var(--radius-md);font-size:13px;font-family:var(--font-mono);min-width:0;transition:border-color var(--transition-fast)}.share-url-box input:focus{outline:none;border-color:var(--accent)}.copy-btn{display:flex;align-items:center;gap:var(--space-1);background:var(--accent);color:var(--bg-primary);border:none;padding:10px var(--space-4);border-radius:var(--radius-md);font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);min-height:40px}.copy-btn:hover{background:var(--accent-hover)}.copy-btn:active{background:var(--accent-active)}.qr-section{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);margin-bottom:var(--space-6)}.qr-code{padding:var(--space-4);background:var(--bg-primary);border-radius:var(--radius-lg);border:1px solid var(--border)}.qr-download{display:flex;align-items:center;gap:6px;background:none;border:1px solid var(--border);color:var(--text-secondary);padding:7px var(--space-4);border-radius:var(--radius-md);font-size:13px;cursor:pointer;transition:all var(--transition-fast);min-height:36px}.qr-download:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.social-buttons{display:flex;gap:var(--space-2);justify-content:center;flex-wrap:wrap}.social-btn{display:flex;align-items:center;gap:var(--space-1);background:var(--bg-primary);border:1px solid var(--border);color:var(--text-secondary);padding:8px var(--space-4);border-radius:var(--radius-md);font-size:13px;cursor:pointer;transition:all var(--transition-fast);min-height:36px}.social-btn:hover{border-color:var(--border-strong);color:var(--text-primary);background:var(--bg-hover)}.project-list-modal{max-width:520px}.project-list-loading{text-align:center;padding:var(--space-8) 0;color:var(--text-muted);display:flex;align-items:center;justify-content:center;gap:var(--space-3)}.project-list-loading:before{content:"";width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.project-list-empty{text-align:center;padding:var(--space-8) 0;color:var(--text-muted)}.project-list-empty>svg{opacity:.4}.project-list-empty p{margin:var(--space-3) 0 var(--space-5);color:var(--text-secondary);line-height:1.5}.project-list{display:flex;flex-direction:column;gap:2px;max-height:400px;overflow-y:auto}.project-list-item{display:flex;align-items:center;gap:var(--space-2)}.project-item-main{flex:1;display:flex;align-items:center;background:none;border:none;color:var(--text-primary);padding:var(--space-3) var(--space-3);border-radius:var(--radius-md);cursor:pointer;text-align:left;width:100%;transition:background var(--transition-fast);min-height:44px}.project-item-main:hover{background:var(--bg-hover)}.project-item-info{display:flex;flex-direction:column;gap:2px;min-width:0}.project-item-title{font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-item-meta{display:flex;align-items:center;gap:var(--space-1);font-size:12px;color:var(--text-muted)}.project-item-delete{display:flex;align-items:center;gap:var(--space-1);background:none;border:none;color:var(--text-muted);padding:8px;border-radius:var(--radius-sm);cursor:pointer;font-size:11px;white-space:nowrap;transition:all var(--transition-fast);min-height:36px;min-width:36px;justify-content:center}.project-item-delete:hover{color:var(--error);background:#ff446614}.project-item-delete.confirm{color:var(--error);background:#ff44661f;padding:8px var(--space-3)}@media (max-width: 768px){.modal{width:100%;max-width:none;border-radius:var(--radius-lg)}.modal-body{padding:var(--space-6)}.share-url-box{flex-direction:column}.copy-btn{justify-content:center}.social-buttons{flex-direction:column}.social-btn{justify-content:center}}.save-nudge{position:fixed;bottom:var(--space-6);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-3);background:var(--bg-elevated);border:1px solid var(--border);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:200;animation:nudgeSlideUp .3s ease-out;max-width:calc(100vw - 32px)}@keyframes nudgeSlideUp{0%{transform:translate(-50%) translateY(20px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.nudge-content{display:flex;align-items:center;gap:var(--space-3)}.nudge-text{font-size:14px;color:var(--text-primary);white-space:nowrap}.nudge-signin{display:flex;align-items:center;gap:var(--space-1);background:var(--accent);color:var(--bg-primary);border:none;padding:7px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);min-height:32px}.nudge-signin:hover{background:var(--accent-hover);box-shadow:var(--shadow-glow)}.nudge-signin:active{background:var(--accent-active)}.nudge-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;min-height:32px;min-width:32px;transition:all var(--transition-fast);flex-shrink:0}.nudge-close:hover{color:var(--text-primary);background:var(--bg-hover)}@media (max-width: 480px){.save-nudge{left:var(--space-4);right:var(--space-4);transform:none;max-width:none}@keyframes nudgeSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}}:root{--bg-primary: #0a0a0f;--bg-surface: #12121a;--bg-elevated: #1a1a25;--bg-hover: #1e1e2a;--bg-tertiary: #191a22;--text-primary: #f0f0f5;--text-secondary: #a0a0b0;--text-muted: #606070;--accent: #00ff88;--accent-hover: #33ffaa;--accent-active: #00cc6e;--accent-dim: rgba(0, 255, 136, .15);--accent-glow: rgba(0, 255, 136, .4);--accent-secondary: #00d4ff;--border: #2a2a35;--border-strong: #3a3b4a;--error: #ff4466;--warning: #ffb800;--success: #00ff88;--info: #00d4ff;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;--font-mono: "SF Mono", "Fira Code", "Fira Mono", "Roboto Mono", monospace;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px var(--accent-glow);--shadow-glow-lg: 0 0 40px var(--accent-glow), 0 0 80px rgba(0, 255, 136, .1);--gradient-accent: linear-gradient(135deg, #00ff88, #00d4ff);--gradient-surface: linear-gradient(180deg, #12121a 0%, #0a0a0f 100%);--gradient-shimmer: linear-gradient(90deg, transparent, rgba(0, 255, 136, .06), transparent);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--space-20: 80px;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}.app{height:100%;display:flex;flex-direction:column}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{background:var(--accent-dim);color:var(--text-primary)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}a{color:var(--accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{text-decoration:underline}button{font-family:inherit;-webkit-tap-highlight-color:transparent}button:active:not(:disabled){transform:scale(.98)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
