.upload-zone{border:2px dashed rgba(255,255,255,.2);border-radius:16px;padding:48px 24px;text-align:center;cursor:pointer;transition:all .2s ease;background:#ffffff05}.upload-zone:hover{border-color:#667eea80;background:#667eea0d}.upload-zone--dragging{border-color:#667eea;background:#667eea1a;transform:scale(1.01)}.upload-input{display:none}.upload-zone-content{display:flex;flex-direction:column;align-items:center;gap:16px;pointer-events:none}.upload-icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#667eea1a;color:#667eea}.upload-zone--dragging .upload-icon{background:#667eea33;animation:bounce .5s ease infinite alternate}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-4px)}}.upload-text{display:flex;flex-direction:column;gap:4px}.primary-text{font-size:18px;font-weight:600;color:#fff}.secondary-text{font-size:14px;color:#ffffff80}.drop-text{font-size:20px;font-weight:700;color:#667eea}.upload-hint{font-size:12px;color:#fff6;margin-top:8px}.upload-page{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(180deg,#0a0a0a,#1a1a2e)}.upload-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;border-bottom:1px solid rgba(255,255,255,.1)}.upload-header h1{font-size:24px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.upload-stats{display:flex;align-items:center;gap:24px}.stat{display:flex;align-items:baseline;gap:8px}.stat-value{font-size:28px;font-weight:700;color:#fff}.stat-label{font-size:14px;color:#ffffff80}.connection-status{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:500}.connection-status.connected{background:#10b98126;color:#10b981}.clear-collage-btn{padding:8px 16px;border:1px solid rgba(239,68,68,.5);border-radius:8px;background:transparent;color:#ef4444;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.clear-collage-btn:hover{background:#ef44441a;border-color:#ef4444}.status-dot{width:8px;height:8px;border-radius:50%;background:currentColor;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.upload-main{flex:1;padding:32px;max-width:800px;margin:0 auto;width:100%}.upload-tasks{margin-top:32px}.tasks-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.tasks-header h2{font-size:18px;font-weight:600;display:flex;align-items:center;gap:12px}.uploading-badge{font-size:12px;font-weight:500;padding:4px 10px;background:#667eea33;color:#667eea;border-radius:12px}.clear-btn{padding:8px 16px;border:1px solid rgba(255,255,255,.2);border-radius:8px;background:transparent;color:#ffffffb3;font-size:14px;transition:all .2s}.clear-btn:hover{background:#ffffff1a;border-color:#ffffff4d}.tasks-list{display:flex;flex-direction:column;gap:12px}.task-item{display:flex;align-items:center;gap:16px;padding:12px;background:#ffffff0d;border-radius:12px;border:1px solid rgba(255,255,255,.1);transition:all .2s}.task-item.task-done{border-color:#10b9814d;background:#10b9810d}.task-item.task-error{border-color:#ef44444d;background:#ef44440d}.task-preview{width:48px;height:48px;border-radius:8px;overflow:hidden;flex-shrink:0}.task-preview img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.task-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.task-name{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-size{font-size:12px;color:#ffffff80}.task-status{flex-shrink:0;min-width:120px;display:flex;align-items:center;justify-content:flex-end}.progress-bar{width:100px;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden;position:relative}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:3px;transition:width .2s}.progress-text{position:absolute;right:-40px;top:50%;transform:translateY(-50%);font-size:12px;color:#ffffffb3;width:35px;text-align:right}.status-text{font-size:14px;color:#ffffff80}.status-text.success{color:#10b981}.status-text.error{color:#ef4444}.error-status{display:flex;align-items:center;gap:12px}.retry-btn{padding:6px 12px;border:1px solid rgba(239,68,68,.5);border-radius:6px;background:transparent;color:#ef4444;font-size:12px;transition:all .2s}.retry-btn:hover{background:#ef44441a}.upload-footer{padding:24px 32px;border-top:1px solid rgba(255,255,255,.1);text-align:center}.display-link{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;font-weight:600;transition:all .2s}.display-link:hover{transform:translateY(-2px);box-shadow:0 8px 24px #667eea66}.collage-photos-section{margin-top:32px}.section-header{margin-bottom:16px}.section-header h2{font-size:18px;font-weight:600}.collage-photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px}.collage-photo-item{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;background:#ffffff0d}.collage-photo-item img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.collage-photo-item:hover .delete-photo-btn{opacity:1}.delete-photo-btn{position:absolute;top:4px;right:4px;width:24px;height:24px;border:none;border-radius:50%;background:#ef4444e6;color:#fff;font-size:16px;line-height:1;cursor:pointer;opacity:0;transition:opacity .2s,transform .2s;display:flex;align-items:center;justify-content:center}.delete-photo-btn:hover{transform:scale(1.1);background:#ef4444}.freeflow-collage{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(2,1fr);gap:6px;background:linear-gradient(135deg,#020a24,#0b2a6b 40%,#071e52 75%,#030e30)}.grid-cell{position:relative;overflow:hidden;background:#ffffff0a}.empty-cell{width:100%;height:100%}.photo-inner{position:absolute;top:0;right:0;bottom:0;left:0}.photo-inner img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.photo-inner--enter{animation:gridPhotoEnter .8s cubic-bezier(.175,.885,.32,1.275) forwards}@keyframes gridPhotoEnter{0%{opacity:0;transform:scale(1.08);filter:blur(8px) brightness(1.5)}60%{opacity:1;filter:blur(0) brightness(1.1)}to{opacity:1;transform:scale(1);filter:blur(0) brightness(1)}}.photo-inner--exit{animation:gridPhotoExit .8s cubic-bezier(.4,0,.2,1) forwards;pointer-events:none}@keyframes gridPhotoExit{0%{opacity:1;transform:scale(1);filter:blur(0)}to{opacity:0;transform:scale(.92);filter:blur(6px)}}.center-title{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;z-index:50;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;background:#020f37bf;padding:1.5rem 2.5rem;border-radius:12px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(100,160,255,.25)}.title-main{font-size:clamp(1.5rem,3vw,2.5rem);font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.08em;margin:0;line-height:1.2}.title-sub{font-size:clamp(.9rem,1.5vw,1.3rem);font-weight:500;color:#ffffffe6;margin:.4rem 0;letter-spacing:.15em;text-transform:uppercase}.title-tagline{font-size:clamp(.7rem,1vw,.9rem);font-weight:400;color:#fff9;margin:.5rem 0 0;letter-spacing:.2em;text-transform:uppercase}.freeflow-empty-hint{position:absolute;top:65%;left:50%;transform:translate(-50%);text-align:center;color:#fff6;font-size:1rem;z-index:50}.floating-branding{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:5;overflow:hidden}.branding-asset{position:absolute;opacity:.85;transform:rotate(var(--brand-rot, 0deg));animation:brandFloat var(--brand-float-dur, 10s) ease-in-out var(--brand-float-delay, 0s) infinite alternate;filter:drop-shadow(0 4px 16px rgba(0,0,0,.4));will-change:transform,opacity}@keyframes brandFloat{0%{transform:translateY(0) translate(0) rotate(calc(var(--brand-rot, 0deg) - 5deg)) scale(1);opacity:.8}25%{transform:translateY(-20px) translate(15px) rotate(var(--brand-rot, 0deg)) scale(1.05);opacity:.9}50%{transform:translateY(-30px) translate(-10px) rotate(calc(var(--brand-rot, 0deg) + 3deg)) scale(1);opacity:.85}75%{transform:translateY(-15px) translate(20px) rotate(calc(var(--brand-rot, 0deg) - 2deg)) scale(1.03);opacity:.9}to{transform:translateY(-10px) translate(-5px) rotate(calc(var(--brand-rot, 0deg) + 5deg)) scale(1);opacity:.8}}.display-page{height:100vh;width:100vw;background:#0a0a0a;position:relative;overflow:hidden}.display-page--error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#ef4444}.display-page--error button{padding:12px 24px;background:#ef4444;color:#fff;border:none;border-radius:8px;font-weight:600}.display-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px;color:#ffffffb3}.loading-spinner{width:48px;height:48px;border:3px solid rgba(255,255,255,.1);border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.status-pill{position:fixed;bottom:24px;right:24px;display:flex;align-items:center;gap:10px;padding:12px 20px;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:24px;font-size:14px;font-weight:600;letter-spacing:.5px;z-index:100;border:1px solid rgba(255,255,255,.1)}.status-indicator{width:10px;height:10px;border-radius:50%}.status-pill.connected .status-indicator{background:#10b981;box-shadow:0 0 12px #10b981;animation:pulse-glow 2s infinite}.status-pill.disconnected .status-indicator{background:#ef4444}.status-pill .status-text{color:#ffffffe6}@keyframes pulse-glow{0%,to{opacity:1;box-shadow:0 0 12px #10b981}50%{opacity:.7;box-shadow:0 0 20px #10b981}}*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}html,body,#root{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0a0a0a;color:#fff;line-height:1.5}img{display:block;max-width:100%}button{font:inherit;cursor:pointer}input,button,textarea,select{font:inherit}a{color:inherit;text-decoration:none}
