body,html{margin:0;padding:0}.app{height:100vh;width:100vw;margin:0;padding:0}.placeholder{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;background-color:teal;color:#fff;font-family:"MS Sans Serif",Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.windows-window{background-color:silver;border:2px solid;border-color:#ffffff #808080 #808080 #ffffff;box-shadow:2px 2px 5px #0003;width:350px}.window-body{padding:12px}.field-row{display:flex;align-items:center;margin-bottom:10px}.field-row label{margin-right:8px;font-size:12px}.windows-input{flex-grow:1;border:2px inset #d4d0c8;background-color:#fff;padding:3px;font-family:inherit}.window-button-row{display:flex;justify-content:center;gap:8px;margin-top:15px}.windows-button{min-width:75px;background-color:silver;border:2px solid;border-color:#ffffff #808080 #808080 #ffffff;padding:2px 10px;font-family:inherit;font-size:12px;box-shadow:1px 1px #d4d0c8}.windows-button:active{border-color:#808080 #ffffff #ffffff #808080;box-shadow:none}.error-message{color:red;background-color:#fee;border:1px solid #ff0000;border-radius:2px;padding:5px 10px;margin:10px 0;font-size:12px;text-align:center}.loading-message{color:navy;background-color:#f0f0f0;border:1px solid #c0c0c0;border-radius:2px;padding:5px 10px;margin:10px 0;font-size:12px;text-align:center;display:flex;align-items:center;justify-content:center}.loading-message:before{content:"";display:inline-block;width:12px;height:12px;border-radius:50%;border:2px solid #c0c0c0;border-top-color:navy;animation:spinner .8s infinite linear;margin-right:8px}.ngrok-notice{background-color:#ffc;border:1px solid #ffcc00;border-radius:2px;padding:10px;margin:10px 0;font-size:12px}.ngrok-notice p{margin:0 0 8px}.ngrok-notice button{font-size:11px;margin-top:5px}.folder-window{width:500px;height:350px;display:flex;flex-direction:column}.window-body{flex:1;padding:8px;overflow:auto}.folder-view{display:flex;flex-wrap:wrap;gap:16px;padding:8px}.folder-item{display:flex;flex-direction:column;align-items:center;width:80px;cursor:pointer;padding:5px;border:1px dotted transparent}.folder-item:hover{background-color:#efefef;border:1px dotted #000000}.folder-item:active{background-color:#316ac5;color:#fff}.folder-icon{width:32px;height:32px;margin-bottom:4px;display:flex;justify-content:center;align-items:center}.folder-icon img{width:100%;height:100%}.fallback-folder-icon{font-size:24px;color:gold}.folder-name{font-size:12px;text-align:center;overflow:hidden;text-overflow:ellipsis;max-width:100%}.status-bar-text{color:#000}.windows-container{display:flex;justify-content:center;align-items:center;height:100vh;background-color:teal;font-family:"MS Sans Serif",Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.windows-window{background-color:silver;border:2px solid;border-color:#ffffff #808080 #808080 #ffffff;box-shadow:2px 2px 5px #0003}.gallery-window{width:80%;height:80%;display:flex;flex-direction:column}.title-bar{background:linear-gradient(to right,navy,#1084d0);color:#fff;display:flex;justify-content:space-between;align-items:center;padding:3px 2px 3px 3px;height:20px}.title-bar-text{font-weight:700;font-size:12px}.title-bar-controls{display:flex}.title-bar-controls button{width:16px;height:14px;margin-left:2px;background-color:silver;border:1px solid;border-color:#ffffff #808080 #808080 #ffffff}.window-toolbar{padding:4px 6px;border-bottom:1px solid #808080;background-color:silver}.window-body{flex:1;overflow:auto;padding:8px;position:relative}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px}.gallery-grid-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px;padding:4px;will-change:transform}.gallery-item{border:1px solid #808080;cursor:pointer;height:120px;overflow:hidden;position:relative;will-change:opacity,transform;transform:translateZ(0);background-color:#e0e0e0}.gallery-item:hover{border-color:#00f}.gallery-item img{width:100%;height:100%;object-fit:cover;transition:opacity .2s ease-in;will-change:opacity}.gallery-item:hover img{transform:scale(1.05)}.image-placeholder{width:100%;height:100%;background-color:#e0e0e0;display:flex;justify-content:center;align-items:center;position:absolute;top:0;left:0;cursor:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEwAACxMBAJqcGAAAAnRJREFUWIXF1j9oE1EcB/DvvbvLpZekaQMWMVCtQkXEooMIglScHBQHcRIEB3F0EZ0UdHHpojgIzg5OgqAgOHQoOojin1IQW6pIrTVNzF3ee+9d7jJcLnep5JIzfcvvfd+P3/fe/d59QETEIrAsC5ZlYWdnBxuNBlZXV7G0tISHDx7g8fQ0frx9i+zyMjzHAQCofI90Po/j585hZGICRy9dQvb0aaTTaei6DlVVoaoqdF2HgH/CHwIdlUoFc3NzmJ2dxcL8PJrNJuOcAwCEEBAAwDlEUlEgj3MuTiUSqOS68BcWMPP8Oe69fg3v+3cIIcCFAOccQggQEYgIRPSvNixFEThy/TomHz3CRK2GfYcPRxttJ/gvuGuaBs/zQFLi8+3b2KpW92zsBhBCQEQTHT90CIm+PkiJ1PUjGYYBTdMQFItQ3r3Dq9nZPYM70RgYGACur4OXywGE0DigwJWVFQSFAnipBDE4iCvT09ja2kJnBfuBLSEEisUizpw7h3QqBQLw6PFjmKbZ9gh2C3chJYZzOfB8HmrcUBLCfXV0uAu+vr6OWq2GzPHjYLkc+PAwDMMIDffljCSEiDUCInq/98UFaJpmGIahrusEAOVyGdPT07h56xb6Dx4EiERn5LvCneQZYwdqtRpSqVRrBmMMpmmiWCyKH/U6GGMQgBPvuPcUb79Oy5UMw3Dt9u12zzCMil8uI1WpYPHlSwjOA/bfcG92h7vGpUwmE4rgOE7geV5gWVZEeHcBIUTCCz0ZYNt29IckSRIAOI7jL124gN7eXsi2VewL7lWyXYS2bbfVFX9UZJZ7eno8AL0AfAAqgARjLJKsK9wb8fhDCG8D2PwJeKiPUGn8Ki0AAAAASUVORK5CYII=),auto}.image-placeholder:after{content:"";width:20px;height:20px;border-radius:50%;border:2px solid #c0c0c0;border-top-color:gray;animation:spinner .8s infinite linear}.image-error{border-color:#ff6b6b!important;cursor:not-allowed}.image-error-placeholder{width:100%;height:100%;display:flex;justify-content:center;align-items:center;background-color:#fee;color:red}.image-error-placeholder span{font-size:24px;font-weight:700;background-color:red;color:#fff;width:30px;height:30px;border-radius:50%;display:flex;justify-content:center;align-items:center}@keyframes spinner{to{transform:rotate(360deg)}}.pagination-controls{display:flex;justify-content:center;align-items:center;margin-top:20px;padding:8px;background-color:silver;border-top:1px solid #808080;position:sticky;bottom:0;z-index:10}.page-indicator{margin:0 15px;font-size:12px;color:navy;-webkit-user-select:none;user-select:none}.windows-button:disabled{color:gray;border-color:#d3d3d3 #a9a9a9 #a9a9a9 #d3d3d3;background-color:#d3d3d3;cursor:not-allowed}.status-bar{height:20px;border-top:1px solid #808080;padding:2px 5px;font-size:11px;display:flex;align-items:center}.windows-button{background-color:silver;border:2px solid;border-color:#ffffff #808080 #808080 #ffffff;padding:2px 10px;font-family:inherit;font-size:12px;min-width:75px;margin-right:4px}.windows-button:active{border-color:#808080 #ffffff #ffffff #808080}.loading-indicator{display:flex;justify-content:center;align-items:center;height:100%;font-size:14px;color:navy;cursor:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEwAACxMBAJqcGAAAAnRJREFUWIXF1j9oE1EcB/DvvbvLpZekaQMWMVCtQkXEooMIglScHBQHcRIEB3F0EZ0UdHHpojgIzg5OgqAgOHQoOojin1IQW6pIrTVNzF3ee+9d7jJcLnep5JIzfcvvfd+P3/fe/d59QETEIrAsC5ZlYWdnBxuNBlZXV7G0tISHDx7g8fQ0frx9i+zyMjzHAQCofI90Po/j585hZGICRy9dQvb0aaTTaei6DlVVoaoqdF2HgH/CHwIdlUoFc3NzmJ2dxcL8PJrNJuOcAwCEEBAAwDlEUlEgj3MuTiUSqOS68BcWMPP8Oe69fg3v+3cIIcCFAOccQggQEYgIRPSvNixFEThy/TomHz3CRK2GfYcPRxttJ/gvuGuaBs/zQFLi8+3b2KpW92zsBhBCQEQTHT90CIm+PkiJ1PUjGYYBTdMQFItQ3r3Dq9nZPYM70RgYGACur4OXywGE0DigwJWVFQSFAnipBDE4iCvT09ja2kJnBfuBLSEEisUizpw7h3QqBQLw6PFjmKbZ9gh2C3chJYZzOfB8HmrcUBLCfXV0uAu+vr6OWq2GzPHjYLkc+PAwDMMIDffljCSEiDUCInq/98UFaJpmGIahrusEAOVyGdPT07h56xb6Dx4EiERn5LvCneQZYwdqtRpSqVRrBmMMpmmiWCyKH/U6GGMQgBPvuPcUb79Oy5UMw3Dt9u12zzCMil8uI1WpYPHlSwjOA/bfcG92h7vGpUwmE4rgOE7geV5gWVZEeHcBIUTCCz0ZYNt29IckSRIAOI7jL124gN7eXsi2VewL7lWyXYS2bbfVFX9UZJZ7eno8AL0AfAAqgARjLJKsK9wb8fhDCG8D2PwJeKiPUGn8Ki0AAAAASUVORK5CYII=),auto}.empty-gallery{display:flex;justify-content:center;align-items:center;height:100%;font-size:14px;color:navy}.loading-cursor{cursor:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEwAACxMBAJqcGAAAAnRJREFUWIXF1j9oE1EcB/DvvbvLpZekaQMWMVCtQkXEooMIglScHBQHcRIEB3F0EZ0UdHHpojgIzg5OgqAgOHQoOojin1IQW6pIrTVNzF3ee+9d7jJcLnep5JIzfcvvfd+P3/fe/d59QETEIrAsC5ZlYWdnBxuNBlZXV7G0tISHDx7g8fQ0frx9i+zyMjzHAQCofI90Po/j585hZGICRy9dQvb0aaTTaei6DlVVoaoqdF2HgH/CHwIdlUoFc3NzmJ2dxcL8PJrNJuOcAwCEEBAAwDlEUlEgj3MuTiUSqOS68BcWMPP8Oe69fg3v+3cIIcCFAOccQggQEYgIRPSvNixFEThy/TomHz3CRK2GfYcPRxttJ/gvuGuaBs/zQFLi8+3b2KpW92zsBhBCQEQTHT90CIm+PkiJ1PUjGYYBTdMQFItQ3r3Dq9nZPYM70RgYGACur4OXywGE0DigwJWVFQSFAnipBDE4iCvT09ja2kJnBfuBLSEEisUizpw7h3QqBQLw6PFjmKbZ9gh2C3chJYZzOfB8HmrcUBLCfXV0uAu+vr6OWq2GzPHjYLkc+PAwDMMIDffljCSEiDUCInq/98UFaJpmGIahrusEAOVyGdPT07h56xb6Dx4EiERn5LvCneQZYwdqtRpSqVRrBmMMpmmiWCyKH/U6GGMQgBPvuPcUb79Oy5UMw3Dt9u12zzCMil8uI1WpYPHlSwjOA/bfcG92h7vGpUwmE4rgOE7geV5gWVZEeHcBIUTCCz0ZYNt29IckSRIAOI7jL124gN7eXsi2VewL7lWyXYS2bbfVFX9UZJZ7eno8AL0AfAAqgARjLJKsK9wb8fhDCG8D2PwJeKiPUGn8Ki0AAAAASUVORK5CYII=),auto}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.image-viewer{width:90%;height:90%;display:flex;flex-direction:column}.viewer-body{display:flex;flex-direction:column;justify-content:center;align-items:center;position:relative}.selected-image{max-width:100%;max-height:calc(100% - 40px);object-fit:contain;cursor:pointer;will-change:transform}.viewer-controls{margin-top:10px;display:flex;justify-content:center}.download-button{background-color:silver;border:2px solid;border-color:#ffffff #808080 #808080 #ffffff;padding:2px 10px;font-family:inherit;font-size:12px}@media (max-width: 768px){.windows-container{height:100%;padding:10px}.gallery-window{width:100%;height:100%;max-height:100vh}.gallery-grid-container{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:5px}.gallery-item{height:100px}.title-bar-text{font-size:11px;max-width:70%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.window-toolbar{padding:3px}.windows-button{min-width:unset;padding:2px 6px;font-size:11px}.pagination-controls{padding:5px}.image-viewer{width:95%;height:80%}.selected-image{max-height:calc(100% - 60px)}.modal-overlay{padding:0}}@media (max-width: 480px){.gallery-grid-container{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:4px}.gallery-item{height:80px}.pagination-controls{flex-wrap:wrap;justify-content:center}.page-indicator{width:100%;text-align:center;margin:5px 0;order:-1}.status-bar{font-size:10px}}@media (max-height: 500px) and (orientation: landscape){.windows-container,.gallery-window{height:auto;min-height:100vh}.gallery-grid-container{grid-template-columns:repeat(auto-fill,minmax(90px,1fr))}.gallery-item{height:90px}}@supports (-webkit-touch-callout: none){.windows-container{height:-webkit-fill-available}.gallery-window{max-height:-webkit-fill-available}}
