:root{--coverflow-card-width:588px;--coverflow-card-height:392px;--grid-gap:5px}body,html{background:#fff;font-family:Arial,sans-serif;margin:0;overflow:hidden;padding:0}#root,body,html{height:100%}#root{display:flex;flex-direction:column;height:100vh}#coverflow{background:#fff;flex:1 1;overflow:hidden;perspective:1500px;position:relative}#coverflow,.coverflow-item{align-items:center;display:flex;justify-content:center}.coverflow-item{background-color:#ccc;border-radius:10px;color:#fff;cursor:pointer;font-size:24px;height:392px;height:var(--coverflow-card-height);position:absolute;transform-style:preserve-3d;width:588px;width:var(--coverflow-card-width);will-change:transform,opacity,background-color}#grid-container{align-items:center;background:#fff;box-sizing:border-box;display:flex;flex:1 1;overflow:hidden;padding:10px;position:relative}#grid,#grid-container{justify-content:center}#grid{grid-gap:5px;grid-gap:var(--grid-gap);align-content:center;display:grid;gap:5px;gap:var(--grid-gap);width:100%}.grid-item{background-color:#4ecdc4;border-radius:5px;cursor:pointer;height:var(--grid-cell-height);transform-origin:center;transition:transform .2s ease;width:var(--grid-cell-width)}.grid-item.selected{outline:3px solid #000}#scale-slider{align-items:flex-end;background:#ccc;border-radius:10px;bottom:20px;cursor:pointer;display:flex;height:150px;opacity:.7;pointer-events:auto;position:absolute;right:20px;width:20px}#slider-thumb{background:#888;border-radius:5px;cursor:grab;height:10px;position:relative;width:100%}.login-modal-backdrop{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.login-modal{background:#fff;border-radius:10px;box-shadow:0 10px 30px #0000004d;max-width:400px;padding:20px;width:90%}.login-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.login-header h2{color:#333;margin:0}.close-btn{background:none;border:none;color:#999;cursor:pointer;font-size:24px}.close-btn:hover{color:#333}.login-form .form-group{margin-bottom:15px}.login-form label{color:#333;display:block;font-weight:700;margin-bottom:5px}.login-form input{border:2px solid #ddd;border-radius:5px;box-sizing:border-box;font-size:16px;padding:12px;width:100%}.login-form input:focus{border-color:#4ecdc4;outline:none}.login-form input.error{border-color:#e74c3c}.error-message{background:#ffe6e6;border-radius:5px;color:#e74c3c;font-size:14px;margin-bottom:15px;padding:10px}.form-actions{display:flex;gap:10px;justify-content:flex-end}.btn-primary,.btn-secondary{border:none;border-radius:5px;cursor:pointer;font-size:14px;font-weight:700;padding:10px 20px}.btn-primary{background:#4ecdc4;color:#fff}.btn-primary:hover:not(:disabled){background:#45b7d1}.btn-secondary{background:#ddd;color:#333}.btn-secondary:hover:not(:disabled){background:#ccc}.btn-primary:disabled,.btn-secondary:disabled{cursor:not-allowed;opacity:.5}.login-info{border-top:1px solid #eee;color:#666;font-size:14px;margin-top:20px;padding-top:20px}.login-info ul{margin:10px 0;padding-left:20px}.admin-panel{position:fixed;right:20px;top:20px;z-index:999}.admin-toggle{background:#333;border:none;border-radius:5px;box-shadow:0 2px 10px #0003;color:#fff;cursor:pointer;font-size:14px;padding:10px 15px}.admin-toggle:hover{background:#555}.admin-controls{background:#fff;border:1px solid #ddd;border-radius:5px;box-shadow:0 5px 20px #0003;margin-top:10px;max-width:300px;min-width:250px;position:absolute;right:0;top:100%}.admin-section{border-bottom:1px solid #eee;padding:15px}.admin-section:last-child{border-bottom:none}.admin-section h4{color:#333;font-size:14px;margin:0 0 10px}.file-input{border:2px dashed #ddd;border-radius:5px;cursor:pointer;padding:8px;text-align:center;width:100%}.file-input:hover{border-color:#4ecdc4}.progress-bar{background:#f0f0f0;border-radius:10px;height:20px;margin-top:10px;overflow:hidden;position:relative}.progress-fill{background:#4ecdc4;height:100%;transition:width .3s ease}.progress-bar span{color:#333;font-size:12px;font-weight:700;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.admin-btn{background:#f9f9f9;border:1px solid #ddd;border-radius:3px;cursor:pointer;display:block;font-size:13px;margin-bottom:5px;padding:8px 12px;text-align:left;width:100%}.admin-btn:hover{background:#f0f0f0}.admin-btn.danger{background:#ffe6e6;border-color:#e74c3c;color:#e74c3c}.admin-btn.danger:hover{background:#fcc}.protected-image{height:auto;max-width:100%;pointer-events:none;user-select:none;-webkit-user-select:none;-moz-user-select:none}.protected-image-error,.protected-image-loading{align-items:center;background:#f5f5f5;border:2px dashed #ddd;border-radius:5px;color:#666;display:flex;font-size:14px;justify-content:center}.protected-image-error{background:#ffe6e6;border-color:#e74c3c;color:#e74c3c}.loading-spinner{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.admin-access-btn{background:#000000b3;border:none;border-radius:20px;bottom:20px;color:#fff;cursor:pointer;font-size:12px;left:20px;opacity:.3;padding:8px 12px;position:fixed;transition:opacity .3s ease;z-index:100}.admin-access-btn:hover{opacity:1}.grid-item.has-image{background:#0000!important;padding:0}.grid-card-image{border-radius:5px;height:100%;width:100%}.empty-position{align-items:center;color:#ffffff80;display:flex;font-family:monospace;font-size:10px;justify-content:center;text-shadow:0 1px 2px #00000080}.grid-item:hover .empty-position{color:#fffc}.protected-image-error,.protected-image-loading{min-height:40px}.coverflow-item canvas{border-radius:10px;pointer-events:none}
/*# sourceMappingURL=main.bfe09f12.css.map*/