.app{max-width:1200px;margin:0 auto}.header{padding:2rem}.header h1{font-size:2.5rem;margin-bottom:.5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header p{color:#888;font-size:1.1rem}.main-content{display:grid;gap:2rem;grid-template-columns:1fr;padding-inline:2rem}@media (min-width: 768px){.main-content{grid-template-columns:1fr 1fr}}.card{background:#ffffff0d;border-radius:12px;padding:2rem;border:1px solid rgba(255,255,255,.1)}.card h2{margin-bottom:1.5rem;font-size:1.5rem}.upload-area{border:2px dashed rgba(255,255,255,.3);border-radius:8px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .3s;margin-bottom:1rem}.upload-area:hover{border-color:#667eea;background:#667eea0d}.upload-area.dragover{border-color:#667eea;background:#667eea1a}.upload-icon{font-size:3rem;margin-bottom:1rem;opacity:.6}.file-input{display:none}.button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff;padding:.75rem 2rem;font-size:1rem;border-radius:6px;cursor:pointer;transition:transform .2s,opacity .2s;font-weight:500}.button:hover{transform:translateY(-2px);opacity:.9}.button:disabled{opacity:.5;cursor:not-allowed;transform:none}.button-secondary{background:#ffffff1a;margin-left:.5rem}.exif-form input[type=text],.exif-form input[type=number]{width:100%;padding:.5rem;border:1px solid rgba(255,255,255,.2);border-radius:4px;background:#ffffff0d;color:inherit;font-size:.9rem;box-sizing:border-box}.exif-form input[type=text]:focus,.exif-form input[type=number]:focus{outline:none;border-color:#667eea;background:#ffffff14}.exif-form label{display:block;margin-bottom:.25rem;font-size:.85rem;font-weight:500;opacity:.9}.preset-select{width:100%;padding:.75rem;border:1px solid rgba(255,255,255,.2);border-radius:4px;background:#ffffff0d;color:inherit;font-size:1rem;cursor:pointer;margin-top:.5rem;margin-bottom:1rem}.preset-select:focus{outline:none;border-color:#667eea}.error-message{background:#f4433633;border:1px solid rgba(244,67,54,.3);color:#f44336;padding:.75rem 1rem;border-radius:6px;margin:1rem 2rem}.preview-image{max-width:100%;width:100%;border-radius:8px;margin:1rem 0;object-fit:contain}.job-list{display:flex;flex-direction:column;gap:1rem;max-height:600px;overflow-y:auto}.job-item{background:#ffffff08;padding:1rem;border-radius:8px;border:1px solid rgba(255,255,255,.1);text-align:left}.job-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.job-id{font-family:monospace;font-size:.9rem;opacity:.7}.job-status{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.job-status.pending{background:#ffc10733;color:#ffc107}.job-status.processing{background:#2196f333;color:#2196f3}.job-status.completed{background:#4caf5033;color:#4caf50}.job-status.failed{background:#f4433633;color:#f44336}.job-actions{margin-top:1rem;display:flex;gap:.5rem}.job-actions button{padding:.5rem 1rem;font-size:.9rem}.loading{text-align:center;padding:2rem;opacity:.7}.loading-spinner{display:inline-block;width:40px;height:40px;border:4px solid rgba(255,255,255,.1);border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:3rem 2rem;opacity:.6}.empty-state-icon{font-size:4rem;margin-bottom:1rem}@media (prefers-color-scheme: light){.card{background:#f5f5f5;border-color:#e0e0e0}.upload-area{border-color:#ccc}.upload-area:hover{background:#667eea0d}.preset-select{border-color:#ccc;background:#fff}.job-item{background:#fff;border-color:#e0e0e0}}.gallery-section{margin-top:3rem;padding:2rem 0;border-top:1px solid rgba(255,255,255,.1)}.gallery-container{max-width:1200px;margin:0 auto}.gallery-header{text-align:center;margin-bottom:3rem}.gallery-header h2{font-size:2rem;margin-bottom:.5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.gallery-header p{font-size:1.1rem;color:#888;margin:0}.carousel-wrapper{position:relative;width:100%;overflow:hidden;padding:3rem 0}.loop-sizer{display:flex;flex-direction:row;gap:2rem;min-width:100%;visibility:hidden;column-gap:2rem;justify-content:flex-start;align-items:center}.loop-track{position:relative;display:flex;flex-direction:row;gap:2rem;justify-content:flex-start;align-items:center;will-change:transform}.loop-clone{position:absolute;left:calc(100% + 2rem);top:0;height:100%;width:100%;display:flex;flex-direction:row;justify-content:flex-start;align-items:center;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;pointer-events:none}.loop-clone[data-inited-appear]{opacity:1;visibility:visible}.carousel-slide{display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0}.carousel-control{position:absolute;top:50%;transform:translateY(-50%);background:#667eeae6;border:none;color:#fff;width:45px;height:45px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:all .3s ease;z-index:10}.carousel-control:hover{background:#667eea;transform:translateY(-50%) scale(1.1)}.carousel-control-prev{left:1rem}.carousel-control-next{right:1rem}.carousel-play-pause{position:absolute;bottom:1rem;right:1rem;background:#667eeae6;border:none;color:#fff;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:all .3s ease;z-index:10}.carousel-play-pause:hover{background:#667eea;transform:scale(1.1)}.carousel-dots{display:flex;justify-content:center;gap:.5rem;margin-top:1.5rem}.dot{width:10px;height:10px;border-radius:50%;border:2px solid rgba(255,255,255,.4);background:transparent;cursor:pointer;transition:all .3s ease}.dot:hover{border-color:#667eeacc}.dot.active{background:#667eea;border-color:#667eea}.gallery-carousel{height:fit-content;width:inherit;border:1px solid rgba(255,255,255,.1);display:flex;justify-content:flex-start;overflow:hidden;position:relative}.gallery-slide{height:100%;padding:0}.carousel-item{flex:0 0 auto;width:320px;height:360px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.1);overflow:hidden;transition:all .3s ease;transform:translateZ(20px);cursor:pointer}.carousel-item:hover{transform:translateZ(40px) translateY(-4px);box-shadow:0 20px 60px #0006,0 0 50px #667eea26;border-color:#667eea4d}.carousel-image-wrapper{position:relative;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:visible}.carousel-image{max-width:90%;max-height:85%;height:auto;display:block;object-fit:contain;transition:transform .3s;box-shadow:0 10px 30px #0006}@media (max-width: 768px){.gallery-carousel{height:500px}.gallery-header h2{font-size:1.5rem}.gallery-header p{font-size:1rem}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}}
